本题要求实现一个求整数的逆序数的简单函数。
函数接口定义:
int reverse( int number );
其中函数reverse须返回用户传入的整型number的逆序数。
裁判测试程序样例:
#include <stdio.h>
int reverse( int number );
int main()
{
int n;
scanf("%d", &n);
printf("%d\n", reverse(n));
return 0;
}
/* 你的代码将被嵌在这里 */
输入样例:
-12340
输出样例:
-4321
int reverse( int number )
{
int p = number,bit = 0,sum = 0;
if( p%10==0 ) p/=10;//末尾的零不用替换
int temp2 = p;//设一个替死鬼,求出number的位数
while( temp2 )
{
temp2 /= 10;
bit++;
}
while( bit )//倒置
{
int temp = p % 10;
for( int i = 1; i < bit; i++ )
{
temp *= 10;
}
sum += temp;
bit--;
p /= 10;
}
return sum;
}