剑指 Offer 17. 打印从1到最大的n位数 - leetcode 剑指offer系列
发布日期:2021-06-29 07:11:54 浏览次数:3 分类:技术文章

本文共 1155 字,大约阅读时间需要 3 分钟。

题目难度: 简单

今天继续更新剑指 offer 系列, 这道题可能是整个系列难度最低的一道了, 非常适合入门同学. 这里同样提供多种方法帮助拓展思路

老样子晚上 6 点 45 分准时更新公众号 每日精选算法题, 大家记得关注哦~ 另外在公众号里回复 offer 就能看到剑指 offer 系列当前连载的所有文章了

题目描述

输入数字 n,按顺序打印出从 1 到最大的 n 位十进制数。比如输入 3,则打印出 1、2、3 一直到最大的 3 位数 999。

  • 用返回一个整数列表来代替打印
  • n 为正整数

题目样例

示例

输入

1

输出

[1,2,3,4,5,6,7,8,9]

题目思考

  1. 如何得到最大值?

解决方案

思路

分析

  • 题目很直白, 我们只需要得到 n 位数的上限, 将其作为循环终点, 从 1 开始循环依次保存到数组即可

实现

  1. 方案 1: 取上限的下一个数, 显然是 pow(10, n), 循环上界小于它即可
  2. 方案 2: 直接取上限, n 位数的上限就是 n 个 9, 通过字符串转换可以直接得到
  3. 方案 3: 还是直接取上限, 通过将当前数字乘以 10 然后加 9 的方式循环生成上限

复杂度

  • 时间复杂度 O(10^N)
    • 需要循环到 10^N 依次输出
  • 空间复杂度 O(1)
    • 只使用了几个变量

代码

方案 1 - 取上限的下一个数

class Solution:    def printNumbers(self, n: int) -> List[int]:        return list(range(1, 10**n))

方案 2 - 利用字符串转换取上限数

class Solution:    def printNumbers(self, n: int) -> List[int]:        mx = int("9" * n)        res = []        for i in range(1, mx + 1):            res.append(i)        return res

方案 3 - 利用循环求上限数

class Solution:    def printNumbers(self, n: int) -> List[int]:        mx = 0        for i in range(n):            mx = mx * 10 + 9        res = []        for i in range(1, mx + 1):            res.append(i)        return res

大家可以在下面这些地方找到我~😊

我的公众号: 每日精选算法题, 欢迎大家扫码关注~😊

每日精选算法题 - 微信扫一扫关注我

转载地址:https://blog.csdn.net/zjulyx1993/article/details/107048080 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:剑指 Offer 18. 删除链表的节点 - leetcode 剑指offer系列
下一篇:剑指 Offer 16. 数值的整数次方 - leetcode 剑指offer系列

发表评论

最新留言

做的很好,不错不错
[***.243.131.199]2024年04月30日 14时14分00秒