鱼C论坛

 找回密码
 立即注册
楼主: zltzlt

[已解决]Python:每日一题 379

[复制链接]
发表于 2020-4-19 15:49:19 | 显示全部楼层

每轮反转,用递归的方式,没有想到!!!

学习啦。谢谢前辈!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-19 15:49:59 | 显示全部楼层
本帖最后由 findland 于 2020-4-19 16:00 编辑

  1. def f379(num):
  2.     while len(num)>1:
  3.         num = num[1::2]
  4.         num.reverse()
  5.     return num[0]


  6. def f379_2(num):
  7.     if len(num)==1:
  8.         print(num[0])
  9.     else:
  10.         num = num[1::2]
  11.         num.reverse()
  12.         f379_2(num)
  13.    
  14.    
  15.    
复制代码

f379 常规方法 f379_2递归方法

评分

参与人数 1荣誉 +2 鱼币 +2 收起 理由
zltzlt + 2 + 2

查看全部评分

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

使用道具 举报

发表于 2020-4-19 15:52:17 | 显示全部楼层

哇,你的这个办法好!!!学习啦,压根没想到用简单的切片也可以实现~~~~

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

使用道具 举报

发表于 2020-4-19 15:59:31 | 显示全部楼层
本帖最后由 findland 于 2020-4-19 16:02 编辑

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

使用道具 举报

发表于 2020-4-19 17:13:42 | 显示全部楼层
xiangjianshinan 发表于 2020-4-19 15:49
每轮反转,用递归的方式,没有想到!!!

学习啦。谢谢前辈!

做个几天的题就会这个套路了,坚持
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-19 17:28:12 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-19 17:29:58 | 显示全部楼层

输入 1000000000 超时
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-19 17:31:59 | 显示全部楼层

输入大数据超时
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-19 17:32:34 | 显示全部楼层

传进的是一个整数啊……
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-19 17:33:33 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-19 17:36:56 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-19 17:37:38 | 显示全部楼层

输入 100000000 超时
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-19 17:38:25 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-19 17:39:55 | 显示全部楼层
xiangjianshinan 发表于 2020-4-19 15:46
终于能做出一个题目啦,好开心!!!
先上代码,再来学习其他前辈的。
自己做过后,再看别人的,并融会贯 ...

输入 6 结果有错
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-19 17:40:50 | 显示全部楼层
findland 发表于 2020-4-19 15:49
f379 常规方法 f379_2递归方法

输入的是一个整数
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-19 18:23:16 | 显示全部楼层

请问->int 是什么意思呀,刚开始学python,小白一个,请指教!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-19 18:24:15 | 显示全部楼层
本帖最后由 zltzlt 于 2020-4-20 13:19 编辑
  1. def d379(n):
  2.     first_list = []
  3.     result_list = []
  4.     for i in range(n):
  5.         first_list.append(i+1)
  6.     while n > 1:
  7.         i = 1
  8.         while i < n:
  9.             result_list.append(first_list[i])
  10.             i = i + 2   
  11.         result_list.reverse()
  12.         first_list = result_list
  13.         result_list = []
  14.         n = len(first_list)
  15.     return first_list[0]
复制代码

评分

参与人数 1荣誉 +3 鱼币 +3 收起 理由
zltzlt + 3 + 3 效率比较低呢

查看全部评分

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

使用道具 举报

发表于 2020-4-19 18:51:10 | 显示全部楼层
小十九 发表于 2020-4-19 18:23
请问->int 是什么意思呀,刚开始学python,小白一个,请指教!

这个是注释,说明它的返回值
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-19 19:43:29 | 显示全部楼层
本帖最后由 TJBEST 于 2020-4-19 23:14 编辑
  1. def fun379(n):
  2.     def inner(start,end,step):
  3.         number = 1 + abs(start-end)//step
  4.         if number > 3:
  5.             if number % 2 == 0:
  6.                 return inner(end,start-step*(start-end)//abs(start-end),step*2)
  7.             else:
  8.                 return inner(end + step*(start-end)//abs(start-end),start-step*(start-end)//abs(start-end),step*2)
  9.         elif number == 3:
  10.             return (start+end)//2
  11.         elif number == 2:
  12.             return end
  13.         else:
  14.             return start
  15.     return inner(1,n,1)
复制代码

评分

参与人数 1荣誉 +5 鱼币 +5 收起 理由
zltzlt + 5 + 5

查看全部评分

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

使用道具 举报

发表于 2020-4-19 20:43:18 | 显示全部楼层
n = input("请输入有序数组最大值:")
li = []
for i in range(1, int(n)+1):
    li.append(i)
while True:
    le = len(li)
    les = int(le/2)
    if le != 1:
        for j in range(0, le-les):
            li.remove(li[j])
        li.reverse()
    else:
        break
print(li[0])

评分

参与人数 1荣誉 +3 鱼币 +3 收起 理由
zltzlt + 3 + 3

查看全部评分

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-19 17:15

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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