您好,登錄后才能下訂單哦!
題目描述: 輸入數字 n ,按順序打印出從 1 最大的 n 位十進制數。
例如:輸入 3,則打印出 1、2、3……一直到最大的 3 位數即 999。
分析:
void Print1ToMaxOfNDigits(int n) { iunt number = 1; int i = 0; while(i++ < n) number *= 10; for(i = 1; i < number; ++i) printf("%d\t", i); }
在字符串上模擬數字的加法
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; }
// 字符串number表示一個數字,在 number上增加1 // 如果做加法溢出,則返回true;否則為false bool Increment(char* number) { bool isOverflow = false; int nTakeOver = 0; int nLength = strlen(number); for(int i = nLength - 1; i >= 0; i --) { int nSum = number[i] - '0' + nTakeOver; if(i == nLength - 1) nSum ++; if(nSum >= 10) { if(i == 0) isOverflow = true; else { nSum -= 10; nTakeOver = 1; number[i] = '0' + nSum; } } else { number[i] = '0' + nSum; break; } } return isOverflow; }
void PrintNumber(char* number) { bool isBeginning0 = true; int nLength = strlen(number); for(int i = 0; i < nLength; ++ i) { if(isBeginning0 && number[i] != '0') isBeginning0 = false; if(!isBeginning0) { printf("%c", number[i]); } } printf("\t"); }
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。