#include <stdio.h>
int main()
{
int num = 0;
scanf("%d",&num);
while (num)
{
printf("%d ", num % 10);
num = num / 10;
}
return 0;
}//不能按顺序打印每个位数的数字,打印123,结果为3 2 1
只能 个位,十位,百位,...... 依次打印,不能按从左到右的顺序依次打印。因为此处只能先模十获得个位的数字,再除以十,将123变成12,再模十,获得十位数的数字,再除以十,将12变成1,...... 以此类推。
#include <stdio.h>
void print(int n)
{
if (n > 9)
{
print(n / 10);
}
printf("%d ", n % 10);
}
int main()
{
int n = 0;
scanf("%d", &n);
print(n);
return 0;
}
此代码的运行如图所示:
代码运行时,顺序如图,所以此次代码运行结果为1 2 3 4 ,先进入内层函数,待内层函数的参数n为一位数(即不满足n>9),才开始由内层的打印开始,外层的打印也接着打印。即满足了先打印个位,再打印十位,......,以此类推。
程序调用自身的编程技巧称为递归。
这种函数print内使用print函数的方法就是函数递归。