鱼C论坛

 找回密码
 立即注册
查看: 1504|回复: 10

[已解决]Python 重构 filter() 函数

[复制链接]
发表于 2020-3-28 08:11:07 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 zltzlt 于 2020-3-29 12:53 编辑

Python 重构 filter() 函数


要求

        1. 完整实现 filter() 的功能
        2. 代码中禁止使用 filter() BIF


格式

  1. def filter(func, iterable):
  2.     # write your code here
复制代码




  1. class filter:
  2.     def __init__(self, func, iterable):
  3.         # your code

  4.     def __iter__(self):
  5.         return self

  6.     def __next__(self):
  7.         # your code
复制代码


例子

  1. >>> list(filter(None, [True, False, 0, 1, '']))
  2. [True, 1]
  3. >>> list(filter(lambda x: x % 2 == 0, range(10)))
  4. [0, 2, 4, 6, 8]
  5. >>> for i in filter(lambda x: x != 5, [5, 4, 5, 6, 7, 3, 5]):
  6.         print(i)

  7.        
  8. 4
  9. 6
  10. 7
  11. 3
复制代码


NOW, IT'S YOUR SHOWTIME !
最佳答案
2020-3-28 08:16:18
  1. def filter(function, iterable,/):
  2.     if function is None:
  3.         for i in iterable:
  4.             if i:
  5.                 yield i
  6.    
  7.     else:
  8.         for i in iterable:
  9.             if function(i):
  10.                 yield i
复制代码

本帖被以下淘专辑推荐:

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-3-28 08:15:29 | 显示全部楼层
我的解法

  1. class filter:
  2.     def __init__(self, func, iterable):
  3.         self.__f = bool if func is None else func
  4.         self.__i = iter(iterable)

  5.     def __iter__(self):
  6.         return self

  7.     def __next__(self):
  8.         while not self.__f(val := next(self.__i)):
  9.             pass
  10.         return val
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-28 08:14:56 | 显示全部楼层
占楼
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-3-28 08:16:18 | 显示全部楼层    本楼为最佳答案   
  1. def filter(function, iterable,/):
  2.     if function is None:
  3.         for i in iterable:
  4.             if i:
  5.                 yield i
  6.    
  7.     else:
  8.         for i in iterable:
  9.             if function(i):
  10.                 yield i
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-28 08:18:03 | 显示全部楼层
本帖最后由 qiuyouzhi 于 2020-3-28 08:38 编辑

写完啦!不喜欢用类写函数
  1. def filter(func, iterable):
  2.     if func is None:
  3.         for each in iterable:
  4.             if each:yield each
  5.     else:
  6.         for each in iterable:
  7.             if func(each):yield each
复制代码

测试用例是都过了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-28 08:45:24 From FishC Mobile | 显示全部楼层
没有能力showtime

点评

不,我坚决不同意楼主的看法!: 5.0
你写写试试呗 快乐嘛  发表于 2020-3-28 09:25
不,我坚决不同意楼主的看法!: 5
你是有能力的  发表于 2020-3-28 08:47
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-28 09:25:15 | 显示全部楼层
_2_ 发表于 2020-3-28 08:45
没有能力showtime

你写写试试呗
快乐就好
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-28 11:20:11 | 显示全部楼层
qiuyouzhi 发表于 2020-3-28 09:25
你写写试试呗
快乐就好

@_2_ 看不见你的回复
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-28 13:44:08 | 显示全部楼层
一个账号 发表于 2020-3-28 11:20
@_2_ 看不见你的回复

嗯,改了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-20 02:25

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表