当前课程知识点:C语言程序设计 > 第7章 用函数实现模块化程序设计 > 7.6 数组作为函数参数2 > 7.6 数组作为函数参数2.mp4
大家好
我是云南大学信息学院丁海燕老师
欢迎走进C语言程序设计课堂
今天我们继续讲解数组作为函数参数
例如
有average(a,10);
实参为数组名a和10
float average(float b[],int n);
形参为数组b和整型变量n
注意
用数组名作函数实参时
不是把数组元素的值传递给形参
而是把实参数组的首元素的地址
传递给形参数组
这样两个数组就共占同一段内存单元
如果实参数组为a 形参数组为b
若a的首元素的地址为1000
则b数组首元素的地址也是1000
显然a[0]与b[0]同占一个单元
等等
假如改变了b[0]的值
也就意味着a[0]的值也改变了
形参数组中各元素的值如发生变化
会使实参数组元素的值同时发生变化
这一点与变量作为函数参数的情况不同
如图所示 函数调用时
实参数组的首元素的地址赋给形参数组
因此a b数组首元素的地址均是1000
a[i] 与b][i]占一个单元
形参 b 实际是一个可以存放地址的变量
下面来看例7.12
用选择法对数组中10个整数
按由小到大排序
所谓选择法就是
先将10个数中最小的数与a[0]对换
再将a[1]到a[9]中最小的数与a[1]对换
等等
每比较一轮
找出一个未经排序的数中最小的一个
共比较9轮
下面以5个数为例
用图示说明选择法排序的步骤
未排序时的情况
3 6 1 9 4
将5个数中最小的数1
与a[0]对换.得到
1 6 3 9 4
将余下的4个数中最小的数3
与a[1]对换.得到
1 3 6 9 4
将余下的3个数中最小的数4
与a[2]对换.得
1 3 4 9 6
将余下的两个数中最小的数6
与a[3]对换.得到
1 3 4 6 9
根据此思路编写程序如下
申明函数sort
用scanf输入数组元素的值
调用sort函数排序
a为数组名 长度为10
用for循环输出排序后的数组元素
sort函数定义如下
共比较n-1趟
每趟比较n-i-1次
即array[j]小于基准元素array[k]
将最小数下标保存在k中
通过三个语句交换两者的值
运行结果 输入10个数
输出排序后的数组如下
程序分析
可以看到在执行函数调用语句
sort a(10);之前和之后
a数组中各元素的值是不同的
原来是无序的
执行sort a 10后
a数组已经排好序了
这是由于形参数组array
已用选择法进行排序了
形参数组改变也使实参数组随之改变
例4 用选择法对数组中10个整数
按由小到大排序
输入并保存以下程序
函数进行声明
输入十个整数
调用sort函数 实参为数组名a
输出排序后的十个数
sort函数的定义如下
通过二重循环进行选择法排序
编译
构建并运行
输入45 2 9 0 -3 54 12 5 66 33
输出排序后的数组
可以用多维数组名
作为函数的实参和形参
在被调函数中对形参数组定义时
可以指定每一维的大小
也可以省略第一维的大小说明
下面来看例7.13
有一个3乘4的矩阵
求所有元素中的最大值
解题思路
先使变量max的初值
等于矩阵中第一个元素的值
然后将矩阵中各个元素的值与max相比
每次比较后都把大者存放在max中
全部元素比较完后
max 的值就是所有元素的最大值
程序如下
申明函数max_value
接下来定义并初始化二维数组
形参数组第一维长度可以省略
不能省略第二维长度
而且要与实参数组第二维大小相同
max_value函数定义如下
该函数的功能是找
二维数组中的最大值
运行结果为
max value is 34
例5 有一个3乘4的矩阵
求所有元素中的最大值
输入并保存以下程序
对函数进行声明
定义一个二维数组a并初始化
输出函数值
调用函数实参为数组名a
定义函数max_value
假设第一个元素array[0][0]为最大值
赋给max
通过二重循环将所有的元素与max相比较
若有更大值
则更新max的值为array[i][j]
最后返回最大值max的值
编译
构建并运行
max值为34
好了 同学们
数组作为函数参数我们就学习到这儿
下节课再见
-1.1 C语言的发展和特点
--1.1自测题
-1.2 一个简单的C语言程序
--讨论单元
--源程序 例1.1 输出一行文字Hello,world!”
--源程序 例1.2 多个函数构成的程序,求两个整数中较大者
--1.2自测题
-1.3 程序、程序设计语言及C程序运行步骤
--讨论单元
--1.3 自测题
-第1章 自测题
-2.1 算法的概念与描述
--讨论单元
--2.1自测题
-2.2 简单算法举例、计算思维与结构化程序设计方法
--2.2 简单算法举例、计算思维与结构化程序设计方法.mp4
--讨论单元
--2.2 自测题
-第2章 自测题
-3.1 C语言程序的简单结构和标识符
--3.1自测题
-3.2 常量、变量与赋值
--讨论单元
--3.2 自测题
-3.3 算术、赋值、自增自减运算符
--3.3 自测题
-3.4 条件、逗号、取地址、求字节运算符以及各类数值型数据间的混合运算
--3.4 条件、逗号、取地址、求字节运算符以及各类数值型数据间的混合运算.mp4
--3.4 自测题
-3.5 输入输出举例与字符的输入输出
--源程序 例求一元二次方程的根。a、b、c由键盘输入。设b2-4ac>0
--源程序 例2. 从键盘输入BOY三个字符,然后把它们输出到屏幕
--3.5 自测题
-3.6 格式化输出printf函数
--3.6自测题
-3.7 格式化输入scanf函数
--讨论单元
--3.7 自测题
-3.8 C语言基本数据类型
--3.8 自测题
-C语言运算符与表达式自测题
-第3章 自测题
-4.1 关系、逻辑运算符和if语句
--讨论单元
--源程序 例4.2 输入两个实数,按代数值由小到大的顺序输出这两个数。
--4.1自测题
-4.2 switch语句
--讨论单元
--4.2自测题
-4.3 选择结构程序举例
--4.3 自测题
-第4章 自测题
-5.1 while和do…while语句
--讨论单元
--源程序 例5.1 用while语句求1+2+3+…+100
--源程序 例5.2 用do…while语句求1+2+3+…+100
--5.1自测题
-5.2 for语句
--5.2 自测题
-5.3 改变循环执行的状态及嵌套循环
--源程序 例5.5 输出100~200之间的不能被3整除的数。
--5.3 自测题
-5.4 循环结构程序举例1
--源程序 例1 按每行输出5个数的形式输出Fibonacci数列的前20项 。
--源程序 例2 判断输入的某个数m是否为素数。若是素数,输出“YES”,若不是,输出“NO”。
--源程序 例3 用牛顿迭代法求方程 2x3+4x2-7x-6=0 在x=1.5附近的根。
--源程序 例4. 求2~10000以内的完全数(一个数的因子(除了这个数本身)之和等于该数本身。)
--5.4 自测题
-5.5 循环结构程序举例2
--5.5自测题
-第5章 自测题
-6.1 一维数组的定义和引用
--讨论单元
--6.1自测题
-6.2 一维数组编程
--6.2 自测题
-6.3 二维数组的定义和引用
--6.3 自测题
-6.4 二维数组编程
--源程序 例2 将一个二维数组行和列的元素互换,存到另一个二维数组中。
--6.4 自测题
-6.5 字符数组的定义、初始化和输入输出
--讨论单元
--6.5 自测题
-6.6 字符串处理函数
--6.6 自测题
-6.7 字符数组编程
--6.7 自测题
-第6章 自测题
-7.1 函数概念以及怎样定义和调用函数
--源程序 例7.1
--7.1自测题
-7.2 函数调用时的数据传递、调用过程及函数返回值
--7.2 函数调用时的数据传递、调用过程及函数返回值.mp4
--讨论单元
--源程序 例7.2
--7.2 自测题
-7.3 对被调函数的声明和函数的嵌套调用
--源程序 例7.4
--7.3 自测题
-7.4 函数的递归调用
--源程序 例7.6
--源程序 例7.7
--7.4 自测题
-7.5 数组作为函数参数1
--讨论单元
--7.5 自测题
-7.6 数组作为函数参数2
--7.6 自测题
-7.7 局部与全局变量,内部与外部函数
--7.7 自测题
-7.8 变量的生存期与局部变量的存储方式
--7.8 自测题
-7.9 全局变量的存储类别
--7.9 自测题
-第7章 自测题
-8.1 指针概念、指针变量的定义和引用
--源程序 例8.1
--讨论单元
--8.1自测题
-8.2 指针变量作为函数参数
--讨论单元
--8.2 自测题
-8.3 数组元素的指针的运算以及通过指针引用数组元素
--8.3 数组元素的指针的运算以及通过指针引用数组元素.mp4
--8.3 自测题
-8.4 用数组名作函数参数
--8.4 自测题
-8.5 通过指针引用多维数组
--8.5 自测题
-8.6 通过指针引用字符串
--8.6 自测题
-8.7 字符指针作函数参数
--8.7 自测题
-8.8 指向函数的指针
--8.8 自测题
-8.9 返回指针值的函数
--源程序 截取子串
--8.9 自测题
-8.10 指针函数和多重指针
--8.10 自测题
-8.11 动态内存分配与指向它的指针变量
--讨论单元
--8.11 自测题
-第8章 自测题
-9.1 定义和使用结构体变量
--9.1自测题
-9.2 使用结构体数组
--讨论单元
--9.2 自测题
-9.3 结构体指针
--9.3 自测题
-第9章 自测题