- 1、本文档共72页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
C语言程序设计清华大学课件第七章数组2
第七章 ;问题:给一组数排序,这组 数该 如何存放呢; 本章要点;; 7.1 一维数组的定义和引用 ;1.一维数组的定义格式为:
类型说明符 数组名[常量表达式];
例如: int a[10];
它表示定义了一个整形数组,数组名为a,此数组有10个元素。
;2.在定义数组时,需要指定数组中元素的个数,方括弧中的常量表达式用来表示元素的个数,即数组长度。
3.常量表达式中可以包括常量和符号常量,但不能包含变量。也就是说,C语言不允许对数组的大小作动态定义,即数组的大小不依赖于程序运行过程中变量的值。;例如: int n;
scanf(“%d″,n); /*在程序中临时输入数
组的大小 */
int a[n];;2.一维数组在内存中的存放;注意:
定义数组时用到的“数组名[常量表达式]” 和引用数组元素时用到的“数组名[下标]” 是有区别的。
例如∶ int a[10];
t=a[6]; ;2.一维数组元素引用的程序实例;对数组元素初始化的实现方法:; 3. 如果想使一个数组中全部元素值为0,可以写成:
int a[10]={0,0,0,0,0,0,0,0,0,0};
或inta[10]={0};
不能写成:int a[10]={0*10};;4. 在对全部数组元素赋初值时,由于数据的个数已经确定,因此可以不指定数组长度。
例如:int a[5]={1,2,3,4,5};
也可以写成 int a[]={1,2,3,4,5};
int a[10]={1,2,3,4,5}; 只初始化前5个元素,后5个元素为0。;例7-1:用数组来处理,求解Fibonacci数列。;for(i=2;i20;i++)
f[i]=f[i-2]+f[i-1];
for(i=0;i20;i++)
{
if(i%5==0) printf(″\n″);
printf(″%12d″,f[i])
} /*For循环结束*/
} /*程序结束*/;程序举例2:用起泡法对10个数排序(由小到大)。 ;;程序流程图如下:;程序实例7.3:
#include stdio.h
void main()
{
int a[10];
int i,j,t;
printf(″input 10 numbers :\n″);
for (i=0;i10;i++)
scanf(%d,a[i]);
printf(\n); ;for(j=0;j9;j++)
for(i=0;i9-j;i++)
if (a[i]a[i+1])
{
t=a[i];a[i]=a[i+1];
a[i+1]=t;
}
printf(″the sorted numbers :\n″);
for(i=0;i10;i++)
printf(″%d ″,a[i]);
printf(″\n??);
}/*程序结束*/; 7.2 二维数组的定义和引用 ;注意:我们可以把二维数组看作是一种特殊的一维数组:它的元素又是一个一维数组。
例如:可以把a看作是一个一维数组,它有3个元素:a[0]、a[1]、a[2],每个元素又是一个包含4个元素的一维数组。; 7.2.1二维数组的定义;地址 值 数组元素;问题:有了二维数组的基础,那么多维数组如何定义呢? ; a[0][0][0]→a[0][0][1]→a[0][0][2]→a[0][0][3]→
a[0][1][0]→a[0][1][1]→a[0][1][2]→a[0][1][3]→
a[0][2][0]→a[0][2][1]→a[0][2][2]→a[0][2][3]→
a[1][0][0]→a[1][0][1]→a[1][0][2]→a[1][0][3]→
a[1][1][0]→a[1][1][1]→a[1][1][2]→a[1][1][3]→
a[1][2][0]→a[1][2][1]→a[1][2][2]→a[1][2][3]→;二维数组元素的表示形式为:
数组名[下标][下标]
例如: a[2][3]
下标可以是整型表达式,如 a[2-1][2*2-1];常出现的错误有:
int a[3][4]; /* 定义a为3×4的数组 */
┆
a[3][4]=3; ;可以用下面4种方法对二维数组初始化:;3.可以对部分元素赋初值。
文档评论(0)