LeetCode题解(Offer62):不断删除圆圈中的第m个数字求最后剩下的数字(Python)
发布日期:2021-06-29 20:01:05
浏览次数:2
分类:技术文章
本文共 576 字,大约阅读时间需要 1 分钟。
题目:(简单)
标签:数学、递归
解法 | 时间复杂度 | 空间复杂度 | 执行用时 |
---|---|---|---|
Ans 1 (Python) | O ( N ) O(N) O(N) | O ( N ) O(N) O(N) | 240ms (54.71%) |
Ans 2 (Python) | O ( N ) O(N) O(N) | O ( 1 ) O(1) O(1) | 80ms (97.26%) |
Ans 3 (Python) |
解法一(递归):
class Solution: def lastRemaining(self, n: int, m: int) -> int: # 处理n==0的情况 if n == 0: return 0 # 处理n>0的情况 else: return (self.lastRemaining(n - 1, m) + m) % n
解法二(迭代):
class Solution: def lastRemaining(self, n: int, m: int) -> int: val = 0 for i in range(1, n + 1): val = (val + m) % i return val
转载地址:https://dataartist.blog.csdn.net/article/details/108639788 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
路过按个爪印,很不错,赞一个!
[***.219.124.196]2024年04月23日 16时40分41秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
Java String字符串
2019-04-30
Java ++a 与 a++
2019-04-30
Java 关系运算符
2019-04-30
Java 三目运算符
2019-04-30
Java 逻辑运算符
2019-04-30
什么是数据库?
2019-04-30
MySQL 简介
2019-04-30
SQL语言
2019-04-30
数据库访问接口
2019-04-30
启动 MySQL服务
2019-04-30
登录MySQL数据库
2019-04-30
MySQL 常用图形管理工具
2019-04-30
MySQL 创建数据库
2019-04-30
查看MySQL数据库定义信息
2019-04-30
MySQL 查看存储引擎
2019-04-30
MySQL 删除数据库
2019-04-30
TypeScript 安装
2019-04-30
TypeScript 基础类型
2019-04-30
typescript 用name作为变量名报错的原因
2019-04-30
TypeScript 变量声明
2019-04-30