C语言初级阶段5——函数2
址传递
1.地址:在定义变量,数组,函数等等,系统会自动给分配他们的内存区域(地址),把这个数据放到这个地址上面。
2.&:&a 得到a的地址编号
3.*:定义指针变量的一个标志;解引用 取内容。
指针变量:存储地址的变量
整型变量:存储整数的变量
int *d =地址
#include<stdio.h>
void fun(int a)
{
}
void fun1(int* p1)
{
printf("%d\n", *p1);
*p1 = 100;
}
int main() {
fun(10);
int a = 10;
int x = 100;
char b = 'a';
float c = 1.1f;
int* d = &a;
fun1(&a);
printf("%d\n", x);
return 0;
}
4.怎么定义一个变量来存储地址==》指针变量
5.怎么获取一个变量的地址 &
6.怎么通过指针变量访问指针变量上所保存的地址内部数据。
7.址传递能够通过形参改变实参的值
数组作为函数的参数
#include<stdio.h>
void fun(int arr[], int len)
{
for (int i = 0; i < len; i++)
{
printf("%d\n", arr[i]);
}
}
int main() {
int a[10] = { 1,2,3,4,5,6 };
int b[5] = { 11,22,33,44,55 };
int c[40] = { 0 };
fun(a, 10);
fun(b, 5);
fun(c, 40);
return 0;
}
函数的递归
1.定义:在一个函数中,重复的调用自己本身(自身调用自身)
#include<stdio.h>
void fun()
{
printf("111111\n");
fun();
}
int main() {
fun();
return 0;
}
#include<stdio.h>
void fun1()
{
static int i = 10;
if (i != 0)
{
i--;
fun1();
}
printf("%d\n", i);
}
void fun2(int n)
{
if (n != 0)
{
fun2(n - 1);
printf("%d\n", n);
}
}
int main() {
fun1();
fun2(4);
return 0;
}
2.递归逆向输出一个数
#include<stdio.h>
void fun3(int n)
{
if (n != 0)
{
printf("%d\n", n % 10);
fun3(n /= 10);
}
}
int main() {
fun3(1234);
return 0;
}
3.斐波那契数列
1 1 2 3 5 8 13… 第n个元素的值=第n-1个元素的值+第n-2个元素
#include<stdio.h>
int fun4(int n)
{
if (n == 1 || n == 2)
return 1;
else
return fun4(n - 1) + fun4(n - 2);
}
int main() {
printf("%d\n", fun4(10));//括号内的数不能超过最大读取数列
return 0;
}
作业1:猴子吃桃:第一题摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个。第二天,又将剩下的桃子吃掉了一半,又多吃了一个。以后每天早上都吃了前一天剩下的一半多吃一个。到最后第十天的时候,还想吃,结果发现就只剩下一个桃子了,请问第一天的时候总共摘了多少桃子,用递归的方式写程序来求结果。
作业2:递归输出10-1
原文地址:http://www.cnblogs.com/George-Judson/p/16861904.html
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,请务用于商业用途!
3. 如果你也有好源码或者教程,可以到用户中心发布,分享有积分奖励和额外收入!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
7. 如遇到加密压缩包,默认解压密码为"gltf",如遇到无法解压的请联系管理员!
8. 因为资源和程序源码均为可复制品,所以不支持任何理由的退款兑现,请斟酌后支付下载
声明:如果标题没有注明"已测试"或者"测试可用"等字样的资源源码均未经过站长测试.特别注意没有标注的源码不保证任何可用性