微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

有没有更有效的方法来反转十进制数?

如何解决有没有更有效的方法来反转十进制数?

我正在尝试更有效地反转十进制数。

#include <stdio.h>

int main()
{

while(1)
 {
 int a,result;
  
 scanf("%d",&a);
  
 result=(a%10*10)+(a/10);

 printf("%d\n",result);

 }
}

当然,这只适用于 2 个十进制数字。

但我试图找出如何以有效的方式(更少的代码)反转更多数字

解决方法

#include <stdio.h>

int main()
{
    long in = 3456789;
    long out = 0;
    while(in)
    {
        out *= 10;
        out += in % 10;
        in /= 10;
    }
    printf("%ld\n",out);
    return 0;
}

这种方式适用于所有类型的数字,无论位数是多少,只要它与数据类型匹配即可。

,

抱歉,我需要更具体一些。更少的代码 –

丑陋但用于“反转”数字的简短代码。

int main(){int c=getchar();if(isdigit(c))main();putchar(c);}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。