数组及函数的应用篇

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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值