用循環來解決~~
M每次除以10, 再用一個變量count來計數,每循環一次 加1,直到這個數除去10後的數小於10 ,count再加1就可以了
實例:整數M=4325,
第一次:4325/10=432,M結果不爲0,cout=1;
第一次:432/10=43,M結果不爲0,cout=2;
第三次:43/10=4,M結果不爲0,count=3;
第四次:M爲4,結果不爲0,count=4;但是M/10爲0,循環結束了
至於保存一個整數的每一位數,我們可以用最常規的方法,用取模(%)和相除(/)連用,來獲取每一位數字~~~
也可以利用上面的循環,因爲每一次除以10後的數,再取模,就可以得到末尾的那位數了,
- <span style="font-size:18px;">#include "iostream"
- using namespace std;
- int main()
- {
- int n,m=0,j=0;
- int a[10];
- cin>>n;
- while(n!=0)
- {
- int x=n%10;
- a[j]=x;// 這裏是爲了保存每一位上的數
- j++;
- n=n/10;//每一次除以10後的結果不爲0,那麼m就可以加1 了
- m++;
- }
- cout<<m<<endl;//輸出位數
- for (int i=0;i<m;i++)
- {
- cout<<a[i]<<' '; //倒敘輸出每一位數
- }
- return 0;
- }</span>