鱼C论坛

 找回密码
 立即注册
查看: 3256|回复: 43

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

[复制链接]
发表于 2020-4-18 19:11:37 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 zltzlt 于 2020-4-18 19:14 编辑

今天的题目:


假设有一个从 1 到 n 的有序整数数组。

首先,从左到右,从第一个数字开始每隔一个数字进行删除,直到列表的末尾。

第二步,在剩下的数字中,从右到左,从倒数第一个数字开始,每隔一个数字进行删除,直到列表开头。

不断重复这两步,直到数组只剩下一个数字

返回数组中剩下的最后一个数字。

示例:

输入:n = 9
输出:6
解释:删除的数字用粗体标示:
1 2 3 4 5 6 7 8 9
2 4 6 8
2 6
6
所以最后剩下的是 6 。


欢迎大家一起答题!
最佳答案
2020-4-18 19:13:10
本帖最后由 永恒的蓝色梦想 于 2020-4-18 19:49 编辑

Python 牛逼!
  1. class Solution:
  2.     def lastRemaining(self, n: int) -> int:
  3.         n=range(1,n+1)
  4.         flag=True

  5.         while (length:=n.__len__())!=1:
  6.             n=n[flag or length&1::2]
  7.             flag=not flag

  8.         return n[0]
复制代码

本帖被以下淘专辑推荐:

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

使用道具 举报

发表于 2020-4-18 19:13:10 | 显示全部楼层    本楼为最佳答案   
本帖最后由 永恒的蓝色梦想 于 2020-4-18 19:49 编辑

Python 牛逼!
  1. class Solution:
  2.     def lastRemaining(self, n: int) -> int:
  3.         n=range(1,n+1)
  4.         flag=True

  5.         while (length:=n.__len__())!=1:
  6.             n=n[flag or length&1::2]
  7.             flag=not flag

  8.         return n[0]
复制代码

评分

参与人数 2荣誉 +10 鱼币 +10 贡献 +3 收起 理由
小十九 + 5 + 5 + 3
zltzlt + 5 + 5

查看全部评分

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

使用道具 举报

发表于 2020-4-18 19:14:28 | 显示全部楼层
示例错了,第二行,被删除的是 4 和 8

评分

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

查看全部评分

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

使用道具 举报

 楼主| 发表于 2020-4-18 19:15:14 | 显示全部楼层
永恒的蓝色梦想 发表于 2020-4-18 19:14
示例错了,第二行,被删除的是 4 和 8

感谢提醒,已经纠正!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-18 19:28:54 From FishC Mobile | 显示全部楼层
占楼
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-4-18 19:47:09 | 显示全部楼层
本帖最后由 March2615 于 2020-4-18 20:03 编辑
  1. # 解题思路:
  2. # 首先 func(2k+1) == func(2k),故只考虑func(2k)
  3. # 找规律:f(2k) = 2 * (k + 1 - f(k))
  4. # 推导过程就是写出来找一下就好,还挺好找的


  5. def daily379(n: int) -> int:
  6.     return 1 if n == 1 else 2 * (n // 2 + 1 - daily379(n // 2))
复制代码


评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-18 19:49:36 | 显示全部楼层
  1. def fun379(n):
  2.     lst = list(range(1, n+1))
  3.     f = 1
  4.     while len(lst) - 1:
  5.         if f:
  6.             lst = lst[1::2]
  7.             lst.reverse()
  8.             f = 0
  9.         else:
  10.             lst = lst[1::2]
  11.             lst.reverse()
  12.             f = 1
  13.     return lst
复制代码

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-18 21:03:07 | 显示全部楼层

小心超过递归深度
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-18 21:04:20 | 显示全部楼层
本帖最后由 塔利班 于 2020-4-18 22:55 编辑
  1. def f379(n):
  2.     res,l=1,[]
  3.     while n>=2:
  4.         n//=2
  5.         l.append(n)
  6.     for e in l[::-1]:
  7.         res=2*(e+1-res)
  8.     return res
复制代码

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-18 21:12:18 | 显示全部楼层

输入12,输出5,这题答案永远不会输出奇数,因为第一步就会干掉所有奇数
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-18 21:37:14 | 显示全部楼层
fan1993423 发表于 2020-4-18 21:12
输入12,输出5,这题答案永远不会输出奇数,因为第一步就会干掉所有奇数

是吗,不是倒数开始删么,,也许我文字学的不好
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-18 21:46:45 | 显示全部楼层
塔利班 发表于 2020-4-18 21:37
是吗,不是倒数开始删么,,也许我文字学的不好

它第一步是从左往右开始删,而且是从1开始删
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-18 22:08:11 | 显示全部楼层
  1. def f379(n):
  2.     ls=list(range(1,n+1))
  3.     while len(ls) != 1:
  4.         if len(ls)%2==0:
  5.             ls=ls[::-2]
  6.         else:
  7.             ls=ls[0:-1][::-2]
  8.     return ls[0]
复制代码

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-18 22:55:15 | 显示全部楼层
fan1993423 发表于 2020-4-18 21:46
它第一步是从左往右开始删,而且是从1开始删

恩,开始没看到删除顺序,
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-19 01:26:40 | 显示全部楼层
本帖最后由 旅途Z 于 2020-4-19 19:04 编辑

啊,没仔细看题,改成输入整数了,但是好像会超时。。
  1. def delete_odd(num):
  2.     def in_func(array):
  3.         length = len(array)
  4.         if length == 1:
  5.             return array[0]
  6.         index = [2 * i for i in range((length + 1) // 2)]
  7.         array = [array[i] for i in range(length) if i not in index]
  8.         array.reverse()
  9.         return in_func(array)
  10.     num_array = [i for i in range(1, num)]
  11.     return in_func(num_array)
复制代码

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-19 03:32:59 | 显示全部楼层
本帖最后由 Python3005 于 2020-4-19 04:04 编辑
  1. def fun(n):
  2.         num = range(1, n+1)
  3.         while len(num) > 1:
  4.                 num = list(filter(lambda x: num.index(x) % 2, num))
  5.                 num.reverse()
  6.         return num[0]
复制代码

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-19 09:21:46 | 显示全部楼层
  1. def f379(n):
  2.     n = list(range(2,n+1,2))
  3.     while len(n) > 1:        
  4.         n.reverse()
  5.         b = (len(n)+1)//2
  6.         for i in range(b):
  7.             n.pop(i)
  8.     return n
复制代码

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-19 10:17:02 | 显示全部楼层
  1. def f(n):
  2.     x=list(range(1,n+1))
  3.     while len(x)!=1:
  4.         x=x[1::2]
  5.         if len(x)!=1:
  6.             x.pop()
  7.             x=x[::-2]
  8.         x.sort()
  9.     return list(x)
复制代码

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-19 13:59:00 | 显示全部楼层
  1. def f(n):
  2.     list1 = list(range(1,n+1))
  3.     def f1(list1):
  4.         if len(list1) == 1:
  5.             return list1[0]
  6.         else:
  7.             list2 = []
  8.             for n in range(1,len(list1),2):
  9.                 list2.append(list1[n])
  10.             list2.reverse()
  11.             return f1(list2)
  12.     return f1(list1)
复制代码

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-19 15:46:06 | 显示全部楼层
终于能做出一个题目啦,好开心!!!
先上代码,再来学习其他前辈的。
自己做过后,再看别人的,并融会贯通,感觉非常好。
  1. l = list(range(1,int(input('请输入一个整数:'))+1))
  2. ta = 1
  3. print(l)
  4. while len(l)>1:
  5.     temp = 1
  6.     templ = l.copy()
  7.     for i in templ:
  8.         if temp % 2 == ta:
  9.             l.remove(i)
  10.         temp +=1
  11.     if ta==1:
  12.         ta=0
  13.     else:
  14.         ta=1
  15.     print(l)

复制代码

评分

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

查看全部评分

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-18 18:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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