逆向顺序输出

逆序数的就是把一个数倒过来,例如:1234那么它的逆序数就为4321,我们该如何是实现呢?当初我是先求出它的位数,接着求余数,余数再乘上所对应的的10的次方,其实10的次方也有专门的函数pow()。

刚开始的程序比较复杂

#include <stdio.h>
#include <math.h>

void main()
{
int number, k, fig=0, i, j, num, sum=0;
printf(“请输入一个整数:”);
scanf("%d",&number);
k=number;
while(k!=0)
{
++fig; //fig用来保存输入的数的位数
k /= 10;
}
for(i=0; i<fig; i++)
{
num = number % 10; //求余数
for(j=0; j<fig-i-1; j++)
num = num*10; //余数乘上所对应的的10的次方
sum = sum + num;
number /= 10;
}
printf(“逆序数为:%d\n”,sum);
}

当知道可以用pow()函数时我们就不用去想怎么实现余数乘上所对应的的10的次方

#include <stdio.h>
#include <math.h>

void main()
{
int number, k, fig=0, i, num, sum=0;
printf(“请输入一个整数:”);
scanf("%d",&number);
k=number;
while(k!=0)
{
++fig; //fig用来保存输入的数的位数
k /= 10;
}
for(i=0; i<fig; i++)
{
num = number % 10; //求余数
sum = sum + num*pow(10, fig-i-1);//余数乘上所对应的的10的次方
number /= 10;
}
printf(“逆序数为:%d\n”,sum);
}

其实还有够更简单的方法来求逆序数

#include <stdio.h>
void main()
{
int number, turnnum=0;
printf(“请输入一个整数:”);
scanf("%d",&number);
while(number)
{
turnnum = turnnum*10 + number%10;
number /= 10;
}
printf(“逆序数为:%d\n”,turnnum);
}

————————————————
版权声明:本文为CSDN博主「freezyh」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/u010180915/article/details/12354805

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值