鱼C论坛

 找回密码
 立即注册
查看: 5274|回复: 75

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

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

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

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

x
今天的题目:


0, 1, ..., n-1 这 n 个数字排成一个圆圈。

从数字 0 开始,每次从这个圆圈里删除第 m 个数字。

求这个圆圈里剩下的最后一个数字。

示例 1:

输入:n = 5, m = 3
输出:3
解释:0、1、2、3、4 这 5 个数字组成一个圆圈,从数字 0 开始,每次删除第 3 个数字,则删除的前 4 个数字依次是 2、0、4、1,因此最后剩下的数字是 3。
示例 2:

输入:n = 10, m = 17
输出:2


欢迎大家一起答题!
最佳答案
2020-3-12 13:35:15
本帖最后由 TJBEST 于 2020-3-12 16:32 编辑

复杂度O(n)
def fun350(n,m):
    result = 0
    for index in range(1,n+1):
        result = (result + m)%index
    return result

本帖被以下淘专辑推荐:

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

使用道具 举报

发表于 2020-3-12 13:23:04 | 显示全部楼层
def f(n,m):
    list1 = [i for i in range(n)]
    while len(list1) > 1:
        a = m-len(list1)
        while a>0:
            a -= len(list1)
        list1 = list1[a+len(list1):] + list1[:a+len(list1)-1]
    return list1[0]

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-3-12 13:32:58 | 显示全部楼层
def f350(n,m):
    list_cir = list(range(n))
    while(n > 1):
        index_num = m % n - 1
        list_cir.pop(index_num)
        n -= 1
        if index_num == -1:
            continue
        else:
            list_cir = list_cir[index_num:] + list_cir[:index_num]
    return (list_cir.pop())

评分

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

查看全部评分

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

使用道具 举报

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

输入以下数据超时:
n = 70866, m = 116922
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-12 13:33:43 | 显示全部楼层
本帖最后由 xiaofan1228 于 2020-3-12 17:05 编辑
n = int(input("Please input a positive range:"))
m = int(input("Please input period:"))
list1 = [i for i in range(n)]
record = []

while True:
    if m > len(list1):
        minStep = m % len(list1)
    else:
        minStep = m
   
    if len(list1) >= 3:
        a = list1.pop(minStep-1)
        record.append(a)
        print("Remove %d" %a)
        list1 = list1[minStep-1:] + list1[:minStep-1]
        print(list1)
    if len(list1) == 2:
        if m % 2:
            a = list1.pop(0)
            record.append(a)
            print('Final==>%d' %list1[0])
        if not m % 2:
            a = list1.pop(1)
            record.append(a)
            print('Final==>%d' %list1[0])

        break

回来了,新手不太明白超时的定义。。。想着节省运算次数就可以避免超时?

更新:卧槽感受到了超时的快感。。。

简直了。。。

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-3-12 13:35:15 | 显示全部楼层    本楼为最佳答案   
本帖最后由 TJBEST 于 2020-3-12 16:32 编辑

复杂度O(n)
def fun350(n,m):
    result = 0
    for index in range(1,n+1):
        result = (result + m)%index
    return result

评分

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

查看全部评分

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

使用道具 举报

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

输入以下数据超时:
n = 70866, m = 116922
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-12 13:50:42 | 显示全部楼层
难度评级:简单
要素分析:模拟,循环
感受:总感觉可以有公式直接算出剩下的数字,但是我没有探索出来。
def solve(n,m):
    temp = list(range(n))
    m -= 1
    i = 0
    while 1:
        try:
            temp[1]
            i += m
            i %= len(temp)
            temp.pop(i)
        except IndexError:
            return temp[0]
if __name__ == '__main__':
    print("示例1 输出:",solve(5,3))
    print("示例2 输出:",solve(10,17))

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-3-12 14:37:42 | 显示全部楼层
我也提供一种思路,先定义n = [i for i in range(n)]*m,从中删减或者直接计算,速度应该会快很多
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-12 14:49:23 | 显示全部楼层
kinkon 发表于 2020-3-12 14:37
我也提供一种思路,先定义n = *m,从中删减或者直接计算,速度应该会快很多

这个不行哦,就第一个列子的话,第三次循环就会把正确答案3去掉
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-12 15:15:20 | 显示全部楼层
本帖最后由 kinkon 于 2020-3-12 15:16 编辑
fan1993423 发表于 2020-3-12 14:49
这个不行哦,就第一个列子的话,第三次循环就会把正确答案3去掉


删不掉啊,n = [i for i in range(n)]*m,这里乘了m,也是可以算出来,现在上班,头脑有点乱
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-12 15:17:11 | 显示全部楼层
本帖最后由 mdphd 于 2020-3-12 15:26 编辑
m = int(input("请输入m的值:"))
n = int(input("请输入n的值:"))
x = 0
for i in range(1, n):
    x = (x + m) % (i + 1)
print(x)
这样应该可以了

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-3-12 15:33:06 | 显示全部楼层
a,b=input().split()
c=[i for i in range(0,int(a))]
index= 0
while len(c)!=1:
    temp=c[:]
    for i in temp:
        index +=1
        if index == int(b):
            c.remove(i)
            index=0
        
            
print(c)

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-3-12 16:02:58 | 显示全部楼层
本帖最后由 zltzlt 于 2020-3-14 13:05 编辑
def ysf(n,m):
     quit=[]
     lst=list((range(0,n)))
     count=1
     if  len(lst)> 1:
         for i in range(0,n):
              if  count==m:
                 quit.append(i)
                 del lst[i]
                 count=1
              else:
                  lst.append(lst.pop(i))
                  count+=1
       print('最后剩下的数字%d'%lst[0])  
       print('淘汰顺序为:'+quit) 

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-3-12 16:26:48 | 显示全部楼层
本帖最后由 TJBEST 于 2020-3-12 16:32 编辑

楼主,见6楼 已更改
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-12 16:48:09 | 显示全部楼层
def func350(n,m):
    a = [i for i in range(0,n)]
    temp = 0
    while n!=1:
        temp = (temp + m)%n - 1
        a.pop(temp)
        if temp== -1:
            temp = 0
        n -=1
    return a[0]

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-3-12 16:52:17 | 显示全部楼层
本帖最后由 fan1993423 于 2020-3-12 16:54 编辑
def fun350(n,m):
    s=list(range(n))
    index=m%n-1
    s.pop(index)
    while len(s)>1:
        if index<0:index=0
        index+=m
        if index>len(s):
            index%=len(s)
        index-=1
        s.pop(index)
    return s[0]
不知道对不对,先写一个

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-3-12 16:53:40 | 显示全部楼层

def zqq(n,m):
        list = [i for i in range(n)]
        length = len(list)
        k =m%length
        while True:
                list.pop(k-1)
                if k!=0:
                        list=list[k-1:n] + list[0:k-1]
                n-=1
                length = len(list)
                k =m%length
                if length == 1:
                        break
        result=list[0]
        print(result)

zqq(5,3)
zqq(10,17)

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-3-12 16:55:55 | 显示全部楼层
TJBEST 发表于 2020-3-12 16:26
楼主,见6楼 已更改

看来12楼的公式是对的了,我没找到公式,刚才测了一下,大数据能出来
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-12 16:56:33 | 显示全部楼层

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-25 01:01

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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