输出一个多位数的各位上的数字

以一个例题为例:

给一个整数,要求:

①求出他是几位数;

②分别输出每一位数字;

③按逆序输出各位数字,例如原数为321,应输出为123.

解题思路:

(1)判断几位数,每次num /= 10然后计数,直到除到原数为0为止,计数的数字就为位数

(2)主要利用“/”和“%”得到各个位的数字,例如123%10就可以得到个位数字3,如果要获取十位数字2,那

就需要123/10得到12然后在继续12%10,依次进行取各个数,然后丢弃最低位,就可以逆序输出各个位的数字.

(3)顺序输出要比逆序复杂一点,但是依然使用的是“/”和“%”两个符号,例如123/100可以得到最高位的数字

如果要获取接下来的这个数字,123%100,就可以丢弃最高位得到23,而此时这是个两位数则23/10就可以得到2.......

源代码:

#include

int Fun(int num)//判断num是几位数
{
int count=0;//定义一个计数器,计数器的值就为位数的值
do
{
num /= 10;
count++;
} while (num != 0);
return count;
}


void Out(int num)//输出每一位数字
{
int key = Fun(num);//将num的位数的值传给key
int count = 1;       
for (int i = 1; i < key; i++)
{
count *= 10;
}
if (num < 0)       //如果数字为负,只显示一个负号
{
printf("-");
num = -num;
}
do
{
printf("%d ",num / count);//输出最高的位数字
num %= count;               //丢弃最高位数字
count /= 10;                   
} while (num != 0);
}


void Rev(int num)//逆序输出
{
if (num < 0)
{
printf("-");
num = -num;
}
do
{
printf("%d ", num%10);//输出最低位的数字
num /= 10;                   //丢弃最低位

} while (num != 0);
}


int main()
{
//printf("%d\n", Fun(25));//简单测试
//printf("%d\n", Fun(0));
//Out(45678);
//Rev(12345);
//Rev(-12345);
return 0;
}


你可能感兴趣的:(输出一个多位数的各位上的数字)