数组及函数的应用篇

来源:互联网 发布:社交网络 thunder 编辑:程序博客网 时间:2024/06/02 02:02
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]);}}

输出结果:



0 0