[CODEVS1130]数字反转

题目描述 Description

给定一个整数,请将该数各个位上数字反转得到一个新数。新数也应满足整数的常见形
式,即除非给定的原数为零,否则反转后得到的新数的最高位数字不应为零.

这是一道水题。我必须承认。蒟蒻表示很开心~~
思路如下:
读入数据后把数字转换为字符,再进行数组反转
也就是c[len-i-1]=s[i];必须重视的一点是数组是从0开始的!!
关于去除前导零:
使用sscanf函数可直接转换~
判断首位是否为零,如果为零,len——,直到不是零,输出原数
 1 #include<iostream>
 2 #include<cstring>
 3 #include<cstdio>
 4 char s[10],c[10];
 5 using namespace std;
 6 int main()
 7 {
 8     int n;
 9     cin>>n;
10     sprintf(s,"%d",n);
11     int len=strlen(s);
12     for(int i=0;i<len;++i)
13      c[len-i-1]=s[i];
14     if(n<0) cout<<"-";
15     sscanf(c,"%d",&n);//转换为int类型后免去了去除前导0的步骤
16     cout<<n;
17     return 0;
18 }

 

 
posted @ 2015-08-04 19:17  Maydaytyh  阅读(254)  评论(0编辑  收藏  举报