题目描述
给定一个整数 N,请将该数各个位上数字反转得到一个新数。新数也应满足整数的常见形式,即除非给定的原数为零,否则反转后得到的新数的最高位数字不应为零(参见样例 2)。
输入格式
一个整数 N。
输出格式
一个整数,表示反转后的新数。
输入输出样例
输入 #1复制
123
输出 #1复制
321
输入 #2复制
-380
输出 #2复制
-83
说明/提示
【数据范围】
−1,000,000,000≤N≤1,000,000,000。
noip2011 普及组第一题
题解:
#include "iostream"
using namespace std;
int main(){
long long n;
cin>>n;
if(n==0){
cout<<0<<endl;
return 0;
}
int a[10000];
int i=0;
bool flag=true;
if(n<0){
flag=false;
n=-n;
}
while(n!=0){
a[i]=n%10;
n/=10;
i++;
}
if(!flag){
cout<<"-";
}
int start=0;
while(start<i&&a[start]==0){
start++;
}
for(;start<i;start++){
cout<<a[start];
}
cout<<endl;
system("pause");
return 0;
}