鱼C论坛

 找回密码
 立即注册
查看: 2668|回复: 12

[技术交流] Python 实现 max()

[复制链接]
发表于 2020-3-21 17:33:49 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 一个账号 于 2020-3-21 18:32 编辑



题目要求:

实现 max() 函数


不得使用内置模块!

格式

  1. def myMax(arr):
  2.         # 你的代码
复制代码


例子

  1. >>> myMax([5,7,1,4,2])
  2. 7
复制代码


NOW, IT'S YOUR SHOWTIME!
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-3-21 17:35:18 | 显示全部楼层
本帖最后由 qiuyouzhi 于 2020-3-21 18:00 编辑

我的答案:
1,最普通的:
  1. >>> def mymax(arr):
  2.         big = arr[0] # 取第一个值,用于之后的判断
  3.         for i in arr:
  4.                 if i > big:
  5.                         big = i
  6.         return big
复制代码

第二种:
  1. >>> def myMax(array):
  2.         arr = array[:]
  3.         for i in range(len(arr)):
  4.                 for j in range(len(arr)):
  5.                         if arr[j] > arr[i]:
  6.                                 arr[i], arr[j] = arr[j], arr[i]
  7.         return arr[-1]
复制代码

简单粗暴
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-21 17:35:45 | 显示全部楼层
qiuyouzhi 发表于 2020-3-21 17:35
我的答案:
1,最普通的:

待会???
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-21 17:39:39 | 显示全部楼层

有问题吗?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-21 17:40:31 | 显示全部楼层
MY CODE:
  1. myMax=lambda arr:__import__('functools').reduce(lambda a,b:(a if a>b else b),arr)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-21 17:48:00 | 显示全部楼层
@zltzlt 过来玩玩?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-21 17:55:29 | 显示全部楼层
qiuyouzhi 发表于 2020-3-21 17:35
我的答案:
1,最普通的:

你这种更改了原数组
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-21 18:01:15 | 显示全部楼层
zltzlt 发表于 2020-3-21 17:55
你这种更改了原数组

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

使用道具 举报

发表于 2020-3-21 18:27:26 | 显示全部楼层
本帖最后由 一个账号 于 2020-3-21 18:57 编辑


增加难度:完全实现 max()
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-23 10:20:50 | 显示全部楼层
一个账号 发表于 2020-3-21 18:27
增加难度:完全实现 max()

没有难度
  1. def max(iterable,/,*vars,key=None,default=None):
  2.     if vars:
  3.         if default is not None:
  4.             raise TypeError("Cannot specify a default for max() with multiple positional arguments")

  5.         greatest=iterable
  6.         flag=key(greatest)

  7.     else:
  8.         iterator=iter(iterable)

  9.         if default is None:
  10.             try:
  11.                 greatest=next(iterator)

  12.             except StopIteration:
  13.                 raise ValueError("max() arg is an empty sequence")
  14.         else:
  15.             greatest=default

  16.     if key is None:
  17.         for var in vars:
  18.             if var>greatest:
  19.                 greatest=var

  20.         return greatest

  21.     else:
  22.         flag=key(greatest)

  23.         for var in vars:
  24.             if (k:=key(var))>flag:
  25.                 flag=k
  26.                 greatest=var

  27.         return greatest
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-23 10:32:58 | 显示全部楼层
  1. >>> def myMax(iterable,/,*vars,key=None,default=None):
  2.     if vars:
  3.         if default is not None:
  4.             raise TypeError("Cannot specify a default for max() with multiple positional arguments")

  5.         greatest=iterable
  6.         flag=key(greatest)

  7.     else:
  8.         iterator=iter(iterable)

  9.         if default is None:
  10.             try:
  11.                 greatest=next(iterator)

  12.             except StopIteration:
  13.                 raise ValueError("max() arg is an empty sequence")
  14.         else:
  15.             greatest=default

  16.     if key is None:
  17.         for var in vars:
  18.             if var>greatest:
  19.                 greatest=var

  20.         return greatest

  21.     else:
  22.         flag=key(greatest)

  23.         for var in vars:
  24.             if (k:=key(var))>flag:
  25.                 flag=k
  26.                 greatest=var

  27.         return greatest

  28. >>> max(1, 2, 3)
  29. 3
  30. >>> myMax(1, 2, 3)
  31. Traceback (most recent call last):
  32.   File "<pyshell#8>", line 1, in <module>
  33.     myMax(1, 2, 3)
  34.   File "<pyshell#6>", line 7, in myMax
  35.     flag=key(greatest)
  36. TypeError: 'NoneType' object is not callable
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-23 11:08:30 | 显示全部楼层
看看
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-3-23 11:59:58 | 显示全部楼层
本帖最后由 永恒的蓝色梦想 于 2020-3-23 12:03 编辑


这句本来是废弃了的……忘删了,感谢指出
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-9 20:01

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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