题目描述:
0,1,···,n-1这n个数字排成一个圆圈,从数字0开始,每次从这个圆圈里删除第m个数字(删除后从下一个数字开始计数)。求出这个圆圈里剩下的最后一个数字。
例如,0、1、2、3、4这5个数字组成一个圆圈,从数字0开始每次删除第3个数字,则删除的前4个数字依次是2、0、4、1,因此最后剩下的数字是3。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/yuan-quan-zhong-zui-hou-sheng-xia-de-shu-zi-lcof
自己的题解:
1)依次遍历这个圆圈删除每个第m个数字;
2)遍历完一遍圆圈后,将剩余的数字按照顺序重新组成一个圆圈,重复第一步,直到剩下一个元素。
代码如下:
运行结果正确,但是超时了。
class Solution:
def lastRemaining(self, n: int, m: int) -> int:
joseph_arr=[]
for i in range(0,n):
joseph_arr.append(i)
new_array=joseph_arr
res_array=[]
while len(res_array)!=n:
if len(new_array)<m:
res_array.append(new_array[m%len(new_array)-1])
res_int=m%len(new_array)-1
else:
for i in range(m-1,len(new_array),m):
res_array.append(new_array[i])
res_int=i
if res_int!=len(new_array)-1:
start_num=new_array[res_int+1]
else :
start_num=new_array[0]
new_array=[]
for j in range(start_num,n):
if joseph_arr[j] not in res_array:
new_array.append(joseph_arr[j])
for j in range(0,start_num-1):
if joseph_arr[j] not in res_array:
new_array.append(joseph_arr[j])
return res_array[-1]
官方题解:
我们将上述问题建模为函数 f(n, m),该函数的返回值为最终留下的元素的序号。
首先,长度为 n 的序列会先删除第 m % n 个元素,然后剩下一个长度为 n - 1 的序列。那么,我们可以递归地求解 f(n - 1, m),就可以知道对于剩下的 n - 1 个元素,最终会留下第几个元素,我们设答案为 x = f(n - 1, m)。
由于我们删除了第 m % n 个元素,将序列的长度变为 n - 1。当我们知道了 f(n - 1, m) 对应的答案 x 之后,我们也就可以知道,长度为 n 的序列最后一个删除的元素,应当是从 m % n 开始数的第 x 个元素。因此有 f(n, m) = (m % n + x) % n = (m + x) % n。
作者:LeetCode-Solution
链接:https://leetcode-cn.com/problems/yuan-quan-zhong-zui-hou-sheng-xia-de-shu-zi-lcof/solution/yuan-quan-zhong-zui-hou-sheng-xia-de-shu-zi-by-lee/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
class Solution:
def lastRemaining(self, n: int, m: int) -> int:
f = 0
for i in range(2, n + 1):
f = (m + f) % i
return f