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

以一个例题为例:

给一个整数,要求:

①求出他是几位数;

②分别输出每一位数字;

③按逆序输出各位数字,例如原数为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;
}


  • 7
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值