将小于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;
}
请问这个代码哪里出了问题,只能输出最后一位数

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


int fun(int k)
{
    int y = 0;
    while (k > 0)
    {
        y = y * 10 + k % 10;
        k /= 10;
    }
    return y;
}

你的fun(k/10);在递归的时候没有取返回值呀
那不白递归了