题目:

输入数字n,按顺序打印出从1到最大的n位十进制数。

比如输入3,打印1,2,3一直到最大的3位数即999。

思路:

1、不考虑n的范围,直接打印。

void Print1ToMaxOfNDigits_1(int n){
int number=1;
for(int i=0;i<n)
number=10*number;
for(int i=1;i<number;i++)
cout<<i<<"\t";
cout<<endl;
}

2、如果n很大,能表示范围超出了int 或者long long的范围,那么就需要考虑大数问题。

最常用也是最容易的方法就是用字符串或者数组来表示大数。

数字最大为n位,因此我们需要一个n+1长度的字符串来存储,最后一位为结束符号'\0',实际位数不够n位时,在字符串前部分补‘0’.(打印的时候将前面的'0'去掉)

步骤:

1、字符串每一位都初始化为‘0’;

2、每一次为字符串表示的数字+1,如果没有超出范围,则打印出来;

如何判断有没有溢出?+

当字符串表示的第一位数即最高位,(最高位+进位)大于或等于10,即判断溢出。

如何打印字符串?

打印字符串时,需要将前部分的'0'省略掉。

递归实现:

n位所有十进制数其实就是n个从0到9的全排列。即把数字的每一位都从0到9排列一遍,就得到了所有的十进制数。

全排列用递归很容易实现,数字的每一位都可能是0-9的一个,然后设置下一位。递归的结束条件是我们已经设置了数字的最后一位。

代码:

#include <iostream>
#include <string.h> using namespace std; bool Increment(char* number){
bool isOverflow=false;
int nTakeOver=0;
int nLength=strlen(number);
int nSum; for(int i=nLength-1;i>=0;i--){
nSum=number[i]-'0'+nTakeOver;
if(i==nLength-1)
nSum++;
if(nSum>=10){
if(i==0)
isOverflow=true;
else{
nSum=nSum-10;
nTakeOver=1;
number[i]='0'+nSum;
}
}
else{
number[i]='0'+nSum;
break;
}
}
return isOverflow;
} void PrintNumber(char* number){
int i=0;
int length=strlen(number);
while(number[i]=='0')
i++;
for(int j=i;j<length;j++)
cout<<number[j];
cout<<"\t";
} void Print1ToMaxOfNDigits(int n){
if(n<=0)
return;
char* number=new char[n+1];
memset(number,'0',n);
number[n]='\0'; while(!Increment(number))
PrintNumber(number); delete number;
} void Print1ToMaxOfNDigits_1(int n){
int number=1;
for(int i=0;i<n)
number=10*number;
for(int i=1;i<number;i++)
cout<<i<<"\t";
cout<<endl;
} int main()
{
Print1ToMaxOfNDigits(3);
return 0;
}
#include <iostream>
#include <string.h> using namespace std; void PrintNumber(char* number){
int i=0;
int length=strlen(number);
while(number[i]=='0')
i++;
for(int j=i;j<length;j++)
cout<<number[j];
cout<<"\t";
} void Print1ToMaxOfNDigits_recursively(char* number,int length,int index){
if(index==length){
PrintNumber(number);
return;
}
for(int i=0;i<10;i++){
number[index]='0'+i;
Print1ToMaxOfNDigits_recursively(number,length,index+1);
}
} void Print1ToMaxOfNDigits_2(int n){
if(n<=0)
return;
char* number=new char[n+1];
number[n]='\0';
Print1ToMaxOfNDigits_recursively(number,n,0);
delete number;
} int main()
{
Print1ToMaxOfNDigits_2(3);
return 0;
}

  

(剑指Offer)面试题12:打印1到最大的n位数的更多相关文章

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

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

  2. 剑指Offer - 九度1515 - 打印1到最大的N位数

    剑指Offer - 九度1515 - 打印1到最大的N位数2013-11-30 01:11 题目描述: 给定一个数字N,打印从1到最大的N位数. 输入: 每个输入文件仅包含一组测试样例.对于每个测试案 ...

  3. 【剑指offer 面试题12】打印1到最大的n位数

    思路: 用n位字符数组表示n位数,通过递归的方式逐层(位)遍历,递归终止时打印. #include "stdio.h" #include "string.h" ...

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

    题目: 输入一个数字n,按顺序打印出从1最大的n位十进制数.比方输入3,则打印出1.2.3最大的三位数即999 这道题的主要陷阱就在大数的处理,仅仅要将这个考虑进去,用字符串来表示.就好说了. 那差点 ...

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

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

  6. C++版 - 剑指offer 面试题23:从上往下打印二叉树(二叉树的层次遍历BFS) 题解

    剑指offer  面试题23:从上往下打印二叉树 参与人数:4853  时间限制:1秒  空间限制:32768K 提交网址: http://www.nowcoder.com/practice/7fe2 ...

  7. 【剑指Offer面试题】 九度OJ1368:二叉树中和为某一值的路径

    题目链接地址: http://ac.jobdu.com/problem.php? pid=1368 题目1368:二叉树中和为某一值的路径 时间限制:1 秒内存限制:32 兆特殊判题:否提交:2252 ...

  8. 剑指Offer——笔试题+知识点总结

    剑指Offer--笔试题+知识点总结 情景回顾 时间:2016.9.23 12:00-14:00 19:00-21:00 地点:山东省网络环境智能计算技术重点实验室 事件:笔试 注意事项:要有大局观, ...

  9. C++版 - 剑指Offer 面试题39:二叉树的深度(高度)(二叉树深度优先遍历dfs的应用) 题解

    剑指Offer 面试题39:二叉树的深度(高度) 题目:输入一棵二叉树的根结点,求该树的深度.从根结点到叶结点依次经过的结点(含根.叶结点)形成树的一条路径,最长路径的长度为树的深度.例如:输入二叉树 ...

  10. C++版 - 剑指Offer 面试题45:圆圈中最后剩下的数字(约瑟夫环问题,ZOJ 1088:System Overload类似)题解

    剑指Offer 面试题45:圆圈中最后剩下的数字(约瑟夫环问题) 原书题目:0, 1, - , n-1 这n个数字排成一个圈圈,从数字0开始每次从圆圏里删除第m个数字.求出这个圈圈里剩下的最后一个数字 ...

随机推荐

  1. Eclipse项目红色叹号解决方法

    情况:就是项目出现红色感叹号 解决方法: 对准项目右键选择Build Path → configure build path 点击eclipse项目的configure build path后,在弹出 ...

  2. SDOI 2017 Round1 解题报告

    Day 1 T1 数字表格 题目大意 · 求\(\prod\limits_{i=1}^n\prod\limits_{j=1}^mFibonacci(\gcd(i,j))\),\(T\leq1000\) ...

  3. POJ 2378 Tree Cutting 3140 Contestants Division (简单树形dp)

    POJ 2378 Tree Cutting:题意 求删除哪些单点后产生的森林中的每一棵树的大小都小于等于原树大小的一半 #include<cstdio> #include<cstri ...

  4. [CodeForces-441E]Valera and Number

    题目大意: 给你一个数x,进行k次操作: 1.有p%的概率将x翻倍: 2.有1-p%的概率将x加1. 问最后二进制下x末尾0个数的期望. 思路: 动态规划. 由于k只到200,所以每次修改只与最后8位 ...

  5. php正则给图片提取/替换/添加alt标签的正则代码

    有的时候我们需要对富文本编辑器的内容做一些处理,例如图片的alt标签.百度的富文本编辑器添加的图片就是没有的,那么我们要添加就必须使用正则了,下面一起来看看如何实现吧. $preg = "/ ...

  6. noip200806火柴棒等式

    试题描述: 给你n根火柴棍,你可以拼出多少个形如“A+B=C”的等式?等式中的A.B.C是用火柴棍拼出的整数(若该数非零,则最高位不能是0).用火柴棍拼数字0-9的拼法如图所示: 注意: 1)加号与等 ...

  7. WebSQL的基本使用过程

    1.创建或打开数据库(openDatabase) var db = openDatabase('dbname', '1.0', 'discription', 2 * 1024); // 目前测试只有C ...

  8. Codeforces Beta Round #7 A. Kalevitch and Chess 水题

    A. Kalevitch and Chess 题目连接: http://www.codeforces.com/contest/7/problem/A Description A famous Berl ...

  9. object-c的http post请求之 ASIFormDataRequest使用

    ASIHTTPRequest类库中的ASIFormDataRequest是实现HTTP协议中的处理POST表单的很好的类库.使用起来非常简单. 在说明之前先需要了解HTTP请求的Get和Post方法. ...

  10. 不用call和apply方法模拟实现ES5的bind方法

    本文首发我的个人博客:前端小密圈,评论交流送1024邀请码,嘿嘿嘿