输入一个正整数,判断它是几位数,并且倒序输出.

怎么去解决这道题目呢?我给大家说一下我的思路吧!举个例子:5除以10为0,15除以100等于0,150除以1000等于0;有此可见一个n位数除以10^(n)结果为0,因此可以用一个死循环来写,当结果为0时,跳出循环。设置一个位数变量a;满足x / i != 0,则a++.

代码如下:

#include
int main()
{    
    int x,t;
    scanf_s("%d",&x);
    if (x == 0)
    {
        printf("%d %d", 1, 0);
        return 1;
    }
    int a = 0;
    for(int i=1;;i=i*10)//这是一个死循环
    {
        
        if (x / i != 0)
        {
            a++;//  位数自加
        }
        else
            break;

    }
    printf("它的位数是:%d\n", a);
    printf("倒序输出:");
    for (int j = 0; j < a; j++)//输出是从低位到高位
    {
        t = x % 10;//求一个数的个位
        x = x / 10;
        printf("%d", t);
    }
    
    return 0;
}
 

你可能感兴趣的:(c,算法,c++,c语言)