有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁。
问第4个人岁数,他说比第3个人大2岁。
问第三个人,又说比第2人大两岁。问第2个人,说比第一个人大两岁。最后
问第一个人,他说是10岁。请问第五个人多大?
#include <stdio.h>
#include <stdlib.h>
int CalAge(int n){
if (n == 1){
return 10;
}
return CalAge(n - 1) + 2;
}
int main(){
printf("%d\n", CalAge(5));
system("pause");
return 0;
}
给一个不多于5位的正整数
求出它是几位数
逆序打印各位数字
#include <stdio.h>
#include <stdlib.h>
void PrintNumber(int n){ //递归实现逆序打印
printf("%d ", n % 10);
if (n > 10){
PrintNumber(n / 10);
}
}
int Num(int n){
int count = 0;
while (n){
++count;
n = n / 10;
}
return count;
}
int main(){
printf("逆序打印:");
PrintNumber(12345);
putchar('\n');
printf("数字位数:%d\n", Num(12345));
system("pause");
return 0;
}
一个5位数,判断它是不是回文数
例如12321是回文数,个位与万位相同,十位与千位相同
#include <stdio.h>
#include <stdlib.h>
int JudgeNumber(int n){
int i;
int sum = 0;
int tmp;
for (i = n; i; i = i / 10){
tmp = i % 10;
sum = sum * 10 + tmp;
}
if (sum == n){
return 1;
}
return 0;
}
int main(){
if (JudgeNumber(12321)){
printf("该数字是回文数!\n");
}
else {
printf("该数字不是回文数!\n");
}
system("pause");
return 0;
}