acm中的一道题

来源:百度知道 编辑:UC知道 时间:2024/06/03 13:05:37
输入一个不多于5位的正整数,要求:

(1)求出它是几位数;

(2)分别输出每一位数字;

(3)按逆序输出各位数字。
Input

输入一个不多于5位的正整数。

Output

输出数据有3行,第一行为正整数位数,第二行为各位数字,第三行为逆序的各位数字。

Sample Input

123

Sample Output

3
1 2 3
3 2 1

#include<stdio.h>
int main()
{
int n,a,b,c,d,e;
scanf("%d",&n);
a=n/10000;
b=(n-a*10000)/1000;
c=(n-a*10000-b*1000)/100;
d=(n-a*10000-b*1000-c*100)/10;
e=(n-a*10000-b*1000-c*100-d*10);
if(e==0&&d==0&&c==0&&b==0&&a==0)printf("0\n");
if(e!=0&&d==0&&c==0&&b==0&&a==0)printf("1\n%d %d\n",e,e);
if(e!=0&&d!=0&&c==0&&b==0&&a==0)printf("2\n%d %d\n%d %d\n",d,e,e,d);
if(e!=0&&d!=0&&c!=0&&b==0&&a==0)printf("3\n%d %d %d\n%d %d %d\n",c,d,e,e,d,c);
if(e!=0&&d!=0&&c!=0&&b!=0&&a==0)printf("4\n%d %d %d %d\n%d

不用那么烦,给个例子你参考下:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int main()
{
char digit[33];
int num, l, i;

scanf("%d", &num);
itoa(num, digit, 10);
l = strlen(digit);

printf("%d\n", l);
printf("%d\n", num);

for (i = l - 1; i >= 0; --i)
putchar(digit[i]);

putchar('\n');
system("PAUSE");
return 0;

}