Six Day
一、递归函数
函数的递归调用有两种形式:直接递归调用 和 间接调用
例如:直接递归
int mul (int n){
int n;
int f;
·····
f=mul(m);
·····
}
例如:间接递归
int mul1(int n){
int m;
······
mul2(m);
······
}
int mul2(int x){
int y;
······
mul1(y);
·······
}
例题:
#include<stdio.h>
void judge();
int main(void) {
judge(); //调用函数
printf("递归函数"); //打印输出
}
void judge() {
int d = 0;
printf("请重新输入:\n");
scanf("%d", &d);
if (d != 0) {
judge(); //调用judge()函数
}
printf("成功了,因为打的是:%d\n", d);
}
输出结果:
二、作用域
作用域的应用:
#include<stdio.h>
int func(int a);
int y = 0;
int main(void) {
int x = 0;
y = func(x); //将函数func()的值赋给y
//printf("%d", b),该语句若在此处,不输出
//return -1,该语句若在此处,不执行后面语句
printf("作用域学习\n");
printf("%d", y);
}
int func(int b) {
printf("%d", b);
//printf("%d", x),该语句若在此处,不输出
return 1;
printf("hahha\n"); //不输出该语句
}
输出结果:
三、函数返回类型
#include<stdio.h>
int func1();
int func2();
int func3();
/*****************返回类型比较***************************/
int main(void) {
int i = 0;
printf("%d\n", func1());
printf("%d\n", func2());
printf("%d", i = i + 1);
}
int func1() {
int i = 1;
return i += 1;
}
int func2() {
int i = 1;
return i + 1;
}
int func3() {
int i = 1;
return i = i + 1;
}
输出结果:
四、数组及函数应用
例题:有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?(使用数组)
#include<stdio.h>
int main(void) {
char a[4] = {1, 2, 3, 4};
int i, j, k, s=0;
for (i = 0; i < 4; i++) {
for (j = 0; j < 4; j++) {
if (a[i] == a[j]) {
continue;
}
for (k = 0; k <4; k++) {
if (a[i] == a[k] || a[j] == a[k]) {
continue;
}
s++;
printf("%d%d%d\n", a[i], a[j], a[k]);
}
}
}
printf("组成%d个互不相同且无重复数字的三位数\n", s);
}
输出结果:
例题:有一个长度为10的数组{12,52,64,33,10,32,53,88,2,90},根据下标将其中某个元素值改为0,将该元素放在数组的最后,并打印数组的每个元素。
#include<stdio.h>
int main(void) {
int a[] = {12, 52, 64, 33, 10, 32, 53, 88, 2, 90};
int num = 0, i, j = 0;
scanf("%d", &num);
for (i = 0; i < 10; i++) {
if (i == 9) {
a[i] = 0;
break;
}
if (i >= num) {
j = i + 1;
a[i] = a[j];
}
}
//遍历
for (i = 0; i < 10; i++) {
printf("%d\t", a[i]);
}
}
输出结果: