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


解析:

easy知道不能用 int 等数字类型表示(大数问题)

在字符串上模拟数字加法

关键点:

1. 怎样用字符串表示n位数?

2. 怎样实现字符串数的自增操作?

3. 怎样打印一个字符串数?



- 申请长度是n+1的字符数组number。 number[0] 是最高位, number[n-1]最低位, number[n] = ‘\0’

- 首先把字符串中的每个数字都初始化为’0’ (注意是字符’0’,不是0)。然后每一次为字符串表示的数字加 1.

- 自增操作时。通过最高位是否会产生进位来推断是否到达最大数。

- 打印字符串数时,应该省略掉高位的无效0

#include <iostream>
#include <stdio.h>
using namespace std;
bool Increment(char* number, int n);
void PrintNum(char* number, int n);
void Print1ToMaxOfNDigits(int n) {
if (n <= 0) // 仅仅要有输入就要考虑输入合法性问题
return;
char* number = new char[n + 1]; // 最后一位放 '\0'
memset(number, '0', n); // 注意是 '0' 不是 0
number[n] = '\0';
while (Increment(number, n) == true) {
PrintNum(number, n);
}
delete []number;
}
bool Increment(char* number, int n)
{
int sum = 0, carry = 0;
for (int i = n - 1; i >= 0; i--) {
sum = (number[i] - '0') + carry;
if (i == n - 1) // 在末位 + 1
sum++;
if (sum >= 10) {
if (i == 0) // 最高位产生进位,已到达最大数
return false;
sum -= 10;
carry = 1;
number[i] = '0' + sum;
} else {
number[i] = '0' + sum; // 已无进位,自增结束
break;
}
}
return true;
}
void PrintNum(char* number, int n)
{
int i = 0;
while (number[i] == '0') // 跳过前面 '0'
i++;
for (; i < n; i++)
printf("%c", number[i]);
cout << " ";
} int main()
{
Print1ToMaxOfNDigits(-1);
Print1ToMaxOfNDigits(0);
Print1ToMaxOfNDigits(3);
// Print1ToMaxOfNDigits(10);
}

全排列法递归打印

我们把每位数字都从 0~9 排列一遍就能得到全部的十进制数,仅仅是打印时省略掉高位无效 0

通过递归实现。从最高位開始。每一位都可能是0~9中的一个数。针对每一种可能设置下一位。递归结束条件是当我们设置了数字的最后一位。

void Print1ToMaxOfNDigits2(int n) {
if (n <= 0)
return;
char* number = new char[n + 1];
memset(number, '0', n);
number[n] = '\0';
Print1ToMaxOfNDigits2Recurisively(number, n, 0);
}
void Print1ToMaxOfNDigits2Recurisively(char* number, int len, int index) {
if (index == len) {
PrintNum(number, len); // 使用上文中的打印函数
return;
}
for (int i = 0; i < 10; i++) {
number[index] = '0' + i;
Print1ToMaxOfNDigits2Recurisively(number, len, index + 1);
}
}

12:打印 1 到最大的 n 位数的更多相关文章

  1. 剑指offer编程题Java实现——面试题12打印1到最大的n位数

    题目:打印1到最大的n位数 输入数字n,按顺序打印输出从1到最大的n位十进制数,比如输入3,打印从1到999. 这道题考察的地方是如何表示大数问题.由于n是任意大的数组,如果n太大的话n位数就超过了l ...

  2. 面试题12:打印1到最大的n位数

    // 面试题12_打印1到最大的n位数.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream> ...

  3. 题目12 打印1到最大的n位数

    ///////////////////////////////////////////////////////////////////////////////////// // 2.打印1到最大的n位 ...

  4. 剑指Offer:面试题12——打印1到最大的n位数(java实现)

    问题描述: 输入数字n,按顺序打印出从1到最大的n位十进制数,比如输入3,则打印出1,2,3一直到最大的3位数即999. 思路1:最简单的想法就是先找出最大的n位数,然后循环打印即可. public ...

  5. 12 打印1到最大的n位数

    输入数字 n,按顺序打印出从 1 最大的 n 位十进制数.比如输入 3,则打印出 1.2.3 一直到最大的 3 位数即 999.由于 n 可能会非常大,因此不能直接用 int 表示数字,而是用 cha ...

  6. 《剑指offer》面试题12 打印1到最大的n位数 Java版

    书中方法:这道题的一个陷阱在于不能用int或者long去存储你要打印的数,然后用打印函数打印,因为这个数可能会很大.如果加1后超出了最大的n位数,就不打印了.用最高位是否进位判断是否结束,打印的时候注 ...

  7. 剑指offer-面试题12.打印1到最大的n位数

    题目:输入数字n,按照打印出从1最大的n位10进制数.比如3,则 打印出1.2.3一直到最大的3位数即999 1.你觉得如果面试会有这么简单的题,那 只能说明你---太天真. 2.n=3尚可,如果n= ...

  8. 《剑指offer》面试题12:打印1到最大的n位数

    面试题12:打印1到最大的n位数 剑指offer题目12,题目如下 输入数字n,按顺序打印出1到最大的n位十进制数,比如输入3,则打印出1,2,3一直到最大的三位数999 方法一 和面试题11< ...

  9. 12:打印1到最大的n位数

    面试题12:打印1到最大的n位数 剑指offer题目12,题目如下 输入数字n,按顺序打印出1到最大的n位十进制数,比如输入3,则打印出1,2,3一直到最大的三位数999 方法一 和面试题11< ...

  10. 【面试题012】打印1到最大的n位数

    [面试题012]打印1到最大的n位数  大数问题 字符串中的每一个字符都是‘0’到‘9’之间的某一个字符,用来表示数字中的一位,因为数字最大是n位的,因此我们需要一个长度为n+1的字符串,字符串的最后 ...

随机推荐

  1. HDU 5171

    这道题本来很水,以前做过一样的,斐波那契数列,用矩阵快速幂的方法求,本来很水,以前做过很多次,为毛做的时候没想到T_T #include <iostream> #include <c ...

  2. MFC窗口去边框、置顶、全屏、激活

    静态移除长提边框非常easy,直接设置"Border"属性为"none"就可以 "Maximize Box", "Minimize ...

  3. 转换Arcgis Server REST接口实现OL2直接调用

    概述: 本文解说怎样通过Arcgis Server REST 的导出地图(Export)接口.实如今OL2中直接以WMS的方式调用Arcgis Server REST服务. 实现思路: 1.rest的 ...

  4. 【DataStructure】The difference among methods addAll(),retainAll() and removeAll()

    In the Java collection framework, there are three similar methods, addAll(),retainAll() and removeAl ...

  5. js中的三种函数写法

    js中的三种函数写法 <script type="text/javascript"> //普通的声明方式 function myFun(m,n){ alert(m+n) ...

  6. 卷积操作中的矩阵乘法(gemm)—— 为什么矩阵乘法是深度学习的核心所在

    1. 全连接 k 个输入: n 个神经元: 每个神经元都会学到一组权值向量,以和输入进行内积运算: n 个输出: 2. 卷积 卷积操作对于高维(多个平面)的输入,单个卷积核的深度应和输入的深度(dep ...

  7. category与协议的不同

    1,category是针对类进行扩展,而且该类必须有里面的所有成员 协议不同可以选择性实现 2,category是针对一个具体的类实现,其他类没有 协议允许任何类使用,只要实现以后只能通过重写修改 3 ...

  8. Spark任务调度

    不多说,直接上干货! Spark任务调度 DAGScheduler 构建Stage—碰到shuffle就split 记录哪个RDD 或者Stage 输出被物化 重新提交shuffle 输出丢失的sta ...

  9. HTML5音频可视化频谱跳动代码

    今天学习到用canvas来写  HTML5音频可视化频谱跳动代码  将代码在此做一总结: <!DOCTYPE html> <html lang="en"> ...

  10. The Vertica Analytic Database:C-Store 7 Years Later笔记

    1.设计目标 Vertica数据库可以说是7年之后的C-Store,在2012年发表的这样一篇论文,描述了现在基于C-Store的一部分改进,当然,Vertica借鉴了很多C-Store的思想,但并非 ...