剑指 Offer(第2版)面试题 17:打印从 1 到最大的 n 位数

news2026/4/2 19:08:50

剑指 Offer(第2版)面试题 17:打印从 1 到最大的 n 位数

  • 剑指 Offer(第2版)面试题 17:打印从 1 到最大的 n 位数
    • 解法1:字符数组
    • 解法2:全排列

剑指 Offer(第2版)面试题 17:打印从 1 到最大的 n 位数

题目描述:

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

首先想到的是 for 循环挨个输出,但是这样的话会有 n 过大,位数过高而造成溢出的情况。

解法1:字符数组

我们使用字符串来模拟数字,这样的话不管多少位我们都可以解决:

构造字符数组:先构造一个 n 位,每一位都为 ‘0’ 的数组,每次最后一位 +1,重复这一过程到溢出为此(如 2 位,加到 100 就会溢出,因此输出 1 ~ 99)

输出:前面有 ‘0’ 的话不输出(如 “001”,应输出 “1”)

代码:

#include <iostream>
#include <string.h>
using namespace std;

void print_number(int number);
void print_arr(char *arr);
bool over(char *arr);

int main()
{
    print_number(2);

    system("pause");
    return 0;
}

void print_number(int number)
{
    char *arr = new char[number + 1];
    memset(arr, '0', number);
    arr[number] = '\0';
    while (!over(arr))
    {
        print_arr(arr);
    }
}

void print_arr(char *arr)
{ // 输出字符数组,第一个为0的话不输出
    bool start = false;
    int count = 0;
    while (!start)
    {
        if (arr[count] != '0')
            start = true;
        count++;
    }
    for (int i = count - 1; i <= strlen(arr); i++)
        cout << arr[i];
    cout << "\t";
}

bool over(char *arr)
{ // 数字加1操作
    arr[strlen(arr) - 1]++;
    int tmp = 0;
    for (int i = strlen(arr) - 1; i >= 0; i--)
    { // 进1相加
        arr[i] += tmp;
        if (arr[i] - '0' > 9)
        {
            arr[i] = '0';
            tmp = 1;
        }
        else
        {
            tmp = 0;
        }
    }
    if (arr[0] == '0' && tmp == 1)
        return true; // 判断溢出
    return false;
}

复杂度分析:

时间复杂度:O(2n-1)。

空间复杂度:O(n),用到了一个长度为 n+1 的字符数组。

解法2:全排列

同样基于字符数组,每一位的数字都是从0 ~9 之间不断变化,因此其是一个排列的问题,我们可以使用递归实现数组的排列,输出的规则同解法 1。

代码:

#include <iostream>
#include <string.h>
using namespace std;

void print_number(int number);
void print_arr(char *arr);
void permutation(char *arr, int index);

int main()
{
    print_number(2);

    system("pause");
    return 0;
}

void print_number(int number)
{
    char *arr = new char[number + 1];
    memset(arr, '0', number);
    arr[number] = '\0';
    for (int i = 0; i < 10; i++)
    {
        arr[0] = i + '0';
        permutation(arr, 0);
    }
}
void permutation(char *arr, int index)
{ // 先递归凑足n位,然后排列输出
    if (index == strlen(arr) - 1)
    {
        print_arr(arr);
        return;
    }
    for (int i = 0; i < 10; i++)
    {
        arr[index + 1] = i + '0';
        permutation(arr, index + 1);
    }
}
void print_arr(char *arr)
{ // 输出字符数组,第一个为0的话不输出
    bool start = false;
    int count = 0;
    while (!start)
    {
        if (arr[count] != '0')
            start = true;
        count++;
    }
    for (int i = count - 1; i <= strlen(arr); i++)
        cout << arr[i];
    cout << "\t";
}

复杂度分析:

时间复杂度:O(2n-1)。

空间复杂度:O(n),递归的深度为 n。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1284613.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

玩转大数据6:实时数据处理与流式计算

引言 在当今的数字化时代&#xff0c;数据正在成为一种新的资源&#xff0c;其价值随着时间的推移而不断增长。因此&#xff0c;实时数据处理和流式计算变得越来越重要。它们在许多领域都有广泛的应用&#xff0c;包括金融、医疗、交通、能源等。本文将探讨实时数据处理和流式…

主题色变量和var实现多套主题换肤

文章目录 一、前言1.1、[VueElementUI实现多套主题换肤](https://blog.csdn.net/u012804440/article/details/133975511)1.2、[VueElementUI实现在线动态换肤](https://blog.csdn.net/u012804440/article/details/133975570) 二、实现2.1、多主题色定义2.2、根节点属性修改2.2.…

UVM验证环境中加入monitor

验证平台必须监测DUT的行为&#xff0c;只有知道DUT的输入输出信号变化之后&#xff0c;才能根据这些信号变化来判定DUT的行为是否正 确。 验证平台中实现监测DUT行为的组件是monitor。 driver负责把transaction级别的数据转变成DUT的端口级别&#xff0c;并驱动给DUT&…

EM32DX-C4【C#】

1外观&#xff1a; J301 直流 24V 电源输入 CAN0 CAN0 总线接口 CAN1 CAN1 总线接口 J201 IO 接线段子 S301-1、S301-2 输出口初始电平拨码设置 S301-3~S301-6 模块 CAN ID 站号拨码开关 S301-7 模块波特率拨码设置 S301-8 终端电阻选择开关 2DI&#xff1a; 公共端是…

Powercli常用命令

背景 vcenter web界面不如命令行快&#xff0c;且不能批量操作。 根据实际需求逐步补充使用到的powercli 命令。 00 通过bat脚本配置terminal标签页 在WindowsTerminal上配置新的标签页&#xff0c;实现打开标签页即默认连接vcenter。 脚本内容如下&#xff1a; echo off p…

Hadoop实验putty文件

&#x1f525;博客主页&#xff1a; A_SHOWY&#x1f3a5;系列专栏&#xff1a;力扣刷题总结录 数据结构 云计算 数字图像处理 很多朋友反馈做hadoop实验中的putty找不到Connection-SSH-Auth路径下找不到Private key for authentication私有密钥&#xff0c;无法将转…

vue: 线上项目element-ui的icon偶尔乱码问题

线上环境偶尔会复现&#xff0c; 具体&#xff1a; 一般使用不会出现这个问题&#xff0c;因为一般引入的是element-ui的css文件&#xff0c;问题出在于为了主题色变化啊&#xff0c;需要用到scss变量引入了scss文件。 import “~element-ui/packages/theme-chalk/src/index”…

IDEA插件:Apipost-Helper

Apipost-Helper是由Apipost推出的IDEA插件&#xff0c;写完接口可以进行快速调试&#xff0c;且支持搜索接口、根据method跳转接口&#xff0c;还支持生成标准的API文档&#xff0c;注意&#xff1a;这些操作都可以在代码编辑器内独立完成&#xff0c;非常好用&#xff01;这里…

solidity实现ERC1155多代币标准

文章目录 1、NFT - 维基百科2、IERC1155MetadataURI3、IERC1155Receiver4、IERC11555、ERC11556、NFT11557、开源地址 1、NFT - 维基百科 ERC-1155 标准于2018年6月由Witek Radomski、Andrew Cooke、Philippe Castonguay、James Therien、Eric Binet及Ronan Sandford提出。此标…

RK3568平台开发系列讲解(Linux系统篇)device_node 转换成 platform_device

🚀返回专栏总目录 文章目录 一、DTB转换规则二、转换源码分析沉淀、分享、成长,让自己和他人都能有所收获!😄 📢本篇将介绍通过设备树 device_node 转换成 platform_device 一、DTB转换规则 device 部分是用 platform_device 结构体来描述硬件资源的, 所以内核最终会将…

LeetCode(47)合并区间【区间】【中等】

目录 1.题目2.答案3.提交结果截图 链接&#xff1a; 合并区间 1.题目 以数组 intervals 表示若干个区间的集合&#xff0c;其中单个区间为 intervals[i] [starti, endi] 。请你合并所有重叠的区间&#xff0c;并返回 一个不重叠的区间数组&#xff0c;该数组需恰好覆盖输入中…

VMware安装Ubuntu系统(Server端,Desktop端步骤一样)

天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物。 每个人都有惰性&#xff0c;但不断学习是好好生活的根本&#xff0c;共勉&#xff01; 文章均为学习整理笔记&#xff0c;分享记录为主&#xff0c;如有错误请指正&#xff0c;共同学习进步。…

【C++】开源:Boost进程间通信库InterProcess配置使用

&#x1f60f;★,:.☆(&#xffe3;▽&#xffe3;)/$:.★ &#x1f60f; 这篇文章主要介绍Boost进程间通信库InterProcess配置使用。 无专精则不能成&#xff0c;无涉猎则不能通。——梁启超 欢迎来到我的博客&#xff0c;一起学习&#xff0c;共同进步。 喜欢的朋友可以关注一…

IntelliJ IDEA图形安装教程

IntelliJ IDEA图形安装教程 之前开始Java程序&#xff0c;一直用的eclipse&#xff0c;觉得还可以。一直听说IntelliJ IDEA比eclipse好用很多&#xff0c;但因为比较懒&#xff0c;也没有学习使用。机缘巧合下&#xff0c;尝试用了下&#xff0c;顿时有种相见恨晚的感觉&#…

翻译: 生成式人工智能的工作原理How Generative AI works

ChatGPT 和 Bard 等系统生成文本的能力几乎像魔法一样。它们确实代表了 AI 技术的一大步进。但是文本生成到底是如何工作的呢&#xff1f;在这个视频中&#xff0c;我们将看看生成式 AI 技术的底层原理&#xff0c;这将帮助你理解你可以如何使用它&#xff0c;以及何时可能不想…

掌控安全 -- POST 注入

POST注入第一题 既然是POST注入&#xff0c;那么再用GET传参的方式就不能用了 万能密码登录一下试试 这里显示成功登录&#xff0c;然后就可以知道登录框这里存在注入&#xff0c;也就是可以构造sql语句进行注入&#xff0c;然后就是正常的注入手法了。 or 11 order by 1# 这…

【算法专题】前缀和

前缀和 前缀和1. 前缀和【模板】2. 二维前缀和【模板】3. 寻找数组的中心下标4. 除自身以外数组的乘积5. 和为K的子数组6. 和可被K整除的子数组7. 连续数组8. 矩阵区域和 前缀和 1. 前缀和【模板】 题目链接 -> Nowcoder -DP34.前缀和【模板】 Nowcoder -DP34.前缀和【模…

【Vulnhub 靶场】【Prime (2021): 2】【简单 - 中等】【20210509】

1、环境介绍 靶场介绍&#xff1a;https://www.vulnhub.com/entry/prime-2021-2,696/ 靶场下载&#xff1a;https://download.vulnhub.com/prime-2021/Prime-2.ova 靶场难度&#xff1a;简单 - 中等 发布日期&#xff1a;2021年5月9日 文件大小&#xff1a;3.7 GB 靶场作者&am…

菜鸟学习日记(python)——运算符

我们进行运算时&#xff0c;需要两类数据&#xff0c;操作数和运算符&#xff0c;例如&#xff1a;ab就是一个运算&#xff0c;它的操作数是a和b&#xff0c;运算符是‘’ 在python中运算符包括以下几大类&#xff1a; 算数运算符比较&#xff08;关系&#xff09;运算符赋值…

图像万物分割——Segment Anything算法解析与模型推理

一、概述 在视觉任务中&#xff0c;图像分割任务是一个很广泛的领域&#xff0c;应用于交互式分割&#xff0c;边缘检测&#xff0c;超像素化&#xff0c;感兴趣目标生成&#xff0c;前景分割&#xff0c;语义分割&#xff0c;实例分割&#xff0c;泛视分割等。 交互式分割&am…