问题:打印反序数。
背景:反序数即镜面数。例如:123456的反序数是654321。
思路:
1.更新输入数:将最右边的数,即个位数独立出来。
2.更新输出数:用*10的方法将整个输出数序列左移一位,再加上刚得到的个位数,即得到反序。
3.循环计算直到输入数一位都不剩。
#include "stdafx.h"
#include <stdlib.h>
#include <math.h>
int reverseDigits(int number)
{
int reverseNumber = 0;
int temp;
while (number > 0) {
temp = number % 10;//得到个位
number = number / 10;//number缩小一位
reverseNumber = reverseNumber * 10 + temp;//reverseNumber增加一位,增加的数为刚取得的个位temp
}
return reverseNumber;
}
void main()
{
int n;
scanf_s("%d", &n);
n = reverseDigits(n);
printf("%d\n", n);
system("pause");
}