m0_67511265 2022-03-03 17:08 采纳率: 69.2%
浏览 72
已结题

将小于32768的数逆序输出

#include<stdio.h>
int fun(int k)
{
int y=0;
if(k%10>0)
{
y=y*10+k%10;
fun(k/10);
}
return y;
}
int main()
{
int n,k;
printf("请输入一个数:");
scanf("%d",&n);
if(n<32768)
{
k=fun(n);
printf("逆序输出为:%d",k);
}
else
printf("输入错误!");
return 0;
}
请问这个代码哪里出了问题,只能输出最后一位数

  • 写回答

2条回答 默认 最新

  • 天影云光 新星创作者: 后端开发技术领域 2022-03-03 17:32
    关注

    你如果不递归的话可以这样写

    
    int fun(int k)
    {
        int y = 0;
        while (k > 0)
        {
            y = y * 10 + k % 10;
            k /= 10;
        }
        return y;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 3月11日
  • 已采纳回答 3月3日
  • 修改了问题 3月3日
  • 创建了问题 3月3日