OJ-倒序输出一个四位整数遇到的坑

题目描述
任意读入一个四位整数,颠倒后输出。
输入
输入一行,只有一个整数x(1000<=x<=9999)。
输出
输出只有一行,包括1个整数。
样例输入
4789
样例输出
9874
代码实现

#include<stdio.h>
int main()
{	
	int a,b;
	int ch[4];
	scanf("%d",&a);
	int i =0;
	while(a)
	{
		b = a % 10;
		ch[i] = b;
		i++;
		a /=10;
	}
	for (i=0;i<4;i++)
	{
		printf("%d",ch[i]);
	}
	return 0;
}

这个代码看似没有问题 但是实际上只能通过75%的数据集
问题出在如果输入1000 应该返回1 但是上面代码却返回了0001
解决这个问题只需要将ch数组中的数字重新拼成一个四位数即可

#include<stdio.h>
int main()
{	
	int a,b;
	int ch[4];
	scanf("%d",&a);
	int i =0;
	while(a!=0)
	{
		b = a % 10;
		ch[i] = b;
		i++;
		a /=10;
	}
		printf("%d",1000*ch[0]+100*ch[1]+10*ch[2]+ch[3]);

	return 0;
}

这样剩下25%的数据集也能通过测试
这个错误其实是题目没有交代清楚 也是自己没有考虑周全 遇到一次解决了下次就会注意到