以一个例题为例:
给一个整数,要求:
①求出他是几位数;
②分别输出每一位数字;
③按逆序输出各位数字,例如原数为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<stdio.h>
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;
}