陷阱: 用最大的n位数-1(数字太大可能产生越界) 应该采用字符串模拟数字自加! 代码如下: #include<iostream> using namespace std; int IsMax(char *number) { int nLength = strlen(number); int CarryBit = 0; bool ret = false; for (int i = nLength-1; i >= 0; i--) { int nSum = number[i] - '0' + CarryBit; if (i == nLength - 1) ++nSum; if (nSum >= 10) { if (i == 0) ret = true; else { nSum -= 10; CarryBit = 1; number[i] = '0' + nSum; } } else { number[i] = '0' + nSum; break; } } return ret; } void Print1ToN(int n) { if (n <= 0) return; char *number = new char[n+1]; memset(number, '0', n); number[n] = '\0'; while (!IsMax(number)) { cout << number << " " ; } } int main() { Print1ToN(10); getchar(); return 0; } 输出部分可以做一些优化将 从第一个不为0的开始输出。
;从1打印到最大的n位数字(字符串模拟数字自加)
原创
©著作权归作者所有:来自51CTO博客作者性感的玉米的原创作品,请联系作者获取转载授权,否则将追究法律责任
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
java检测字符串是否包含数字和字母
java检测字符串是否包含数字和字母的方法。
git 字符串 System java -
打印出数字字符串的偶位数
打印出数字字符串的偶位数
C语言的一些基础程序 -
打印从1到最大的n位数
面试题:输入数值n,打印从1到最大的n位数,例如输入n=3,
#include ios 大整数 位运算 字符数组