用循环来解决~~
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; a[j]=x; j++; n=n/10; m++; } cout<<m<<endl; for (int i=0;i<m;i++) { cout<<a[i]<<' '; } return 0; }</span>
转载于:https://www.cnblogs.com/nxxshxf/p/6195350.html
相关资源:输入数字计算位数并颠倒输出