用循环来解决~~
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>