鱼C论坛

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

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

[复制链接]
发表于 2020-3-12 22:53:12 | 显示全部楼层
第一次做题
  1. n,m = map(int,input().split())
  2. list1 = list(range(n))
  3. print(list1)
  4. i,j = 0,1
  5. while i < n:
  6.     if j%m == 0:
  7.         list1.remove(list1[i])
  8.         j = 0
  9.         i -= 1
  10.     i += 1
  11.     j += 1
  12.     if i == len(list1):
  13.         i = 0
  14.     if len(list1) == 1:
  15.         break
  16. print(list1[0])   
复制代码

评分

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

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-12 22:55:53 | 显示全部楼层
本帖最后由 EEasyy 于 2020-3-12 22:57 编辑
  1. def f(n, m):
  2.     if(n == 1):
  3.         return n
  4.     return (f(n - 1, m) + m - 1) % n + 1

  5. n = int(input("请输入n的值:"))
  6. m = int(input("请输入m的值:"))
  7. answer=f(n,m) - 1
  8. print(answer)
复制代码

做过类似的,稍微一改就出来了

评分

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

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-13 00:34:01 | 显示全部楼层
风风魔王 发表于 2020-3-12 18:27
大佬能解释下为什么m要先减1呢?

因为按照我的方法,每一次去掉一个数字后,原本的索引相当于自行增加了1,如果还是原来的 m 那么,每一次绕圈点名总是会多数一个,所以在最开始就将 m 减去 1.
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-13 00:55:15 | 显示全部楼层
本帖最后由 派生小生 于 2020-3-13 01:02 编辑
  1. def f350(n,m:int)->str:
  2.     if m == 0:
  3.         return "m为0,只能是%d形成的圈圈了" % n
  4.     elif n == 0:
  5.         return n
  6.     elif n == 1:
  7.         list_n = [0,1]
  8.         num = m % 2
  9.         return list_n[num]
  10.     else:
  11.         list_n = []
  12.         for i in range(n):
  13.             list_n.append(i)
  14.         num_now = 0
  15.         num_lenth = len(list_n)
  16.         while num_lenth > 1:
  17.             num_now += m -1
  18.             if num_now < num_lenth:
  19.                 num_now = num_now
  20.             elif num_now == num_lenth:
  21.                 num_now = 0
  22.             elif num_now // num_lenth > 1:
  23.                 num_now = num_now % num_lenth
  24.             else:
  25.                 num_now -= num_lenth
  26.             list_n.pop(num_now)
  27.             num_lenth -= 1
  28.         return list_n[0]
  29. a = int(input("请输入a的值:"))
  30. b = int(input("请输入b的值:"))
  31. print(f350(a,b))
复制代码

评分

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

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-13 02:07:48 | 显示全部楼层
本帖最后由 Stubborn 于 2020-3-13 03:32 编辑

循环单链表??最近在学数据结构,练习一下,效率很不好,不用测哈

  1. class CircularSingleStrand:
  2.     class _Node:
  3.         def __init__(self, value):
  4.             self.val = value
  5.             self.next = None

  6.     def __init__(self):
  7.         self._head = None

  8.     def add(self, iterable):
  9.         self.l = len(iterable)
  10.         l = []
  11.         for val in iterable:
  12.             node = self._Node(val)
  13.             l.append(node)
  14.             node.next = self._head
  15.             self._head = node
  16.         l[0].next = l[-1]
  17.         del l

  18.     def result(self, n, m):
  19.         self.add(range(n-1, -1, -1))
  20.         c = 1
  21.         node = self._head
  22.         while self.l != 0:
  23.             pre_node = node
  24.             c += 1
  25.             node = node.next
  26.             if not c % m:
  27.                 pre_node.next = node.next
  28.                 self.l -= 1
  29.         return node.val


  30. t = CircularSingleStrand()
  31. print(t.result(12, 17))
复制代码

评分

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

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-13 04:35:56 | 显示全部楼层
本帖最后由 Python3005 于 2020-3-13 04:38 编辑
  1. def fun(n , m):
  2.         lst =  list(range(n))
  3.         temp = m
  4.         def new_fun(lst, m):
  5.                 while m > (l := len(lst)):
  6.                         m -= l
  7.                 lst = lst[m:] + lst[:m-1]       
  8.                 if len(lst) == 1:
  9.                         return lst[0]
  10.                 else:
  11.                         return new_fun(lst, temp)
  12.         return new_fun(lst, temp)
复制代码

评分

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

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-13 23:58:02 | 显示全部楼层

你的我看了很多遍,不明白其中的原理,可以帮忙解释下吗?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-14 13:04:27 | 显示全部楼层
xiaofan1228 发表于 2020-3-12 13:33
回来了,新手不太明白超时的定义。。。想着节省运算次数就可以避免超时?

更新:卧槽感受到了超时 ...

解答错误

输入:n = 88, m = 10
输出:81
预期结果:3
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-14 13:05:45 | 显示全部楼层

输入 n = 5, m = 1 超时
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-14 13:08:14 | 显示全部楼层

输入 n = 5, m = 3 出错
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-14 13:08:40 | 显示全部楼层
whosyourdaddy 发表于 2020-3-12 16:48
def func350(n,m):
    a =
    temp = 0

2244 ms
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-14 13:09:02 | 显示全部楼层
fan1993423 发表于 2020-3-12 16:52
不知道对不对,先写一个

2280 ms
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-14 13:09:57 | 显示全部楼层
Herry2020 发表于 2020-3-12 16:53
def zqq(n,m):
        list =
        length = len(list)

输入以下数据超时:

  1. n = 70866, m = 116922
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-14 13:11:37 | 显示全部楼层
蒋博文 发表于 2020-3-12 17:32
总觉得楼主测试我的时间总是到了次日的次日

解答错误

输入:n = 5, m = 1
输出:1
预期结果:4
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-14 13:12:57 | 显示全部楼层

输入以下数据超时:

  1. n = 861, m = 1192
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-14 13:14:00 | 显示全部楼层

解答错误

输入:n = 5, m = 3
输出:0
预期结果:3
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-14 13:15:51 | 显示全部楼层
Grrr 发表于 2020-3-12 20:10
刚学习的新手 能帮忙看看我这个是啦出错了么?
  File test350.py", line 16, in
    test350(3,5)

解答错误

输入:n = 5, m = 3
输出:0
预期结果:3
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-14 13:16:48 | 显示全部楼层

输入以下数据超时:

  1. n = 70866, m = 116922
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-14 13:18:07 | 显示全部楼层

输入以下数据超时:

  1. n = 70866, m = 116922
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-14 13:18:26 | 显示全部楼层
请问一下,我的这个没有超时吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-5 02:47

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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