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
(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;
}