输入数字N,按顺序打印出从1到N位的十进制数。比如输入3,则打印出1、2、3一直到最大的3位数即999
2012-11-02 21:36
344 查看
最近找工作,看剑指offer这本书,刚好看到这个题目,感觉上面的代码有一层循环稍有冗余,想试试是不是自己想错了,顺便自己练练手。
/* 输入数字N,按顺序打印出从1到N位的十进制数。比如输入3,则打印出1、2、3一直到最大的3位数即999 考虑:大数问题 直接用大数模拟太复杂,直接用深搜比较方便(n个从0到9的全排列) */ #include <iostream> #include <cstdio> #include <cstring> using namespace std; void Print(char *number, int n) { int i=0; for(; i<n; i++) if(number[i]!='0') break; if(i==n) //0的特殊处理 return; // char *a = &number[i]; //效果同下面 // cout<<a<<endl; for(; i<n; i++) printf("%c", number[i]); printf("\n"); } void PrintRecursively(char *number, int n, int index) { if(index==n) { Print(number, n); return; } for(int i=0; i<10; i++) { number[index]=i+'0'; PrintRecursively(number, n, index+1); } } void PrintToMaxOfNDigits(int n) { if(n<=0) return ; char *number = new char[n+1]; memset(number, '0', sizeof(number)); number ='\0'; PrintRecursively(number, n, 0); delete[] number; } int main() { int n; while(scanf("%d", &n)!=EOF) PrintToMaxOfNDigits(n); return 0; }
相关文章推荐
- 输入数字n,按顺序打印出1到最大的n位十进制数。比如输入3,则打印出1、2、3一直到最大的3位数即999。
- 面试题12:输入数字n,按照顺序打印出从1最大的n位十进制数。比如输入3,则打印出1、2、3一直到最大的3位数即999
- 打印输入数字n,按顺序输出从1最大的n位10进制数。比如输入3,则输出1、2、3一直到最大的3位数即999。
- 输入数字n,按顺序输出从1最大的n位10进制数。比如输入3,则输出1、2、3一直到最大的3位数即999
- 输入数字n,按顺序打印出从1到最大十进制的数,比如输入3,打印出1,2,3......999
- 打印1到最大的n位数 题目:输入数字n,按顺序打印出从1最大的n位十进制数。
- 输入数字n,按顺序打印出从0到最大n位十进制数
- 1.输入n,打印一到n位最大数字,比如输入3,打印1到999
- 输入数字n,打印1到最大的n位数
- 输入数字n,按顺序输出从1最大的n位10进制数。比如输入3,则输出1、2、3
- 输入数字n,按顺序打印出从1到最大的n位十进制数
- C语言 打印1到最大的N位数(输入3,打印1,2,3~999)
- 输入数字n,顺序打印出1到n位的十进制最大数
- 输入数字n,按顺序打印出从1到最大的n位十进制数
- 输入数字n,按顺序打印出从1到最大的n位十进制数
- 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字1,2,3,4,8
- 输入数字 n,按顺序输出从 1 最大的 n 位 10 进制数
- 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字1,2,3,4,8
- 从控制台输入一个三位数,如果是水仙花数(是指一个三位数,其各位数字立方和等于该数 )就打印“是水仙花数”,否则打印“不是水仙花数”
- 输入一个不多于5位的正整数,求它是几位数并且逆序打印出个位数字