首先是第一问:统计数字n是个几位数;
这一问相对比较简单,思路就是对n整除,循环进行,直到n=0,返回循环的次数,方法使用while循环,for循环,或者do...while循环都可以进行,这里我选择了代码量最少的do...while 循环。
int Count(int n)
{
int tmp = 0;
do
{
n /= 10;
tmp ++;
}while(n != 0);
return tmp;
}
接下来就是顺序和逆序,我一开始以为顺序比较简单,每次讲最大的数保存下来就可以了,但实际操作的时候才发现,由于每次进行‘%’的时候,最大位要除的数字都不一样,所以顺序输出反而更麻烦,相比较逆序输出就比较简单了。
逆序输出的思路就是,每次对n除余,得到最小位数字,再将n的位数除10,循环进行,直到n=0时跳出循环;
这里我选的还是do...while循环。
void PrintReverse(int n)
{
if(n < 0)
{
printf("-");//这里是对负数的逆序输出加一个“负号”
}
do
{
printf("%d ",n%10);
n /= 10;
}while(n != 0);
printf("\n");
}
然后关于逆序输出还有一个特点,如果考题是将一个十进制数字用其他进制(比如二十进制)逆序输出出来,那么这个代码进行微调之后便可解决。
具体方法如下:
void PrintReverse(int n)
{
if(n < 0)
{
printf("-");//这里是对负数的逆序输出加一个“负号”
}
do
{
printf("%d ",n%20);//此处的“除余”改成其他进制即可将数字使用其他进制输出
n /= 10;
}while(n != 0);
printf("\n");
}
最后是顺序输出:
我们下次再说,该睡觉了