统计数字n是个几位数,并将其逆序和顺序输出

​​​​​​​       这道题是学完循环分支这一节之后看到的题目,本来写的时候就想的比较简单,在听完老师的讲解之后,发现这道题所蕴含的内容和深入思考之后的问题还有很多,觉得十分有必要记录下来,供以后想起来了可做参考。

首先是第一问:统计数字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");
}

最后是顺序输出:

我们下次再说,该睡觉了

你可能感兴趣的:(C语言)