- 1、本文档共54页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
信息学奥林匹克竞赛C语言课程胶片4-定向改编V1.0解读
C语言
Part 4 for NOI
数组
函数
问题:有如下几组数据,它们分别该如何存储呢?
一个班学生的学习成绩
一行文字
一个矩阵
这些数据的特点是:
具有相同的数据类型
使用过程中需要保留原始数据
C语言为这些数据,提供了一种构造数据类型:数组。
数组
数组是一组具有相同数据类型的数据的有序集合。
一维数组
类型说明符 数组名[常量表达式];
例如: int a[10];
它表示定义了一个整形数组,数组名为a,此数组有10个元素。
数组名定名规则和变量名相同,遵循标识符定名规则。
在定义数组时,需要指定数组中元素的个数,方括弧中的常量表达式用来表示元素的个数,即数组长度。例如,指定a[10],表示a数组有10个元素,注意下标是从0开始的,不存在数组元素a[10]。
C89规定常量表达式中可以包括常量和符号常量,但不能包含变量,即不允许对数组的大小作动态定义,数组的大小不依赖于程序运行过程中变量的值。例如,下面这样定义数组是不行的:
一位数组
变长数组(C89不允许,C99允许)
float a[0]; /* 数组大小为0没有意义 */
int b(2)(3); /* 不能使用圆括号 */
下标可以是整型常量,也可以是整型表达式
A[2+1], a[2*3], a[7/3]
int n;
scanf(%d, n);
int array[n];
if(n 0)
{
array[0] = 100;
printf(array[0]=%d\n, array[0]);
}
else
printf(array length is zero.\n);
数组的存储
一维数组: float mark[100];一个元素占4个字节
每个数据元素占用的字节数,就是基本类型的字节数
int i, a[10];
for (i = 0; i 10; i++)
{
a[i] = i;
}
for (i = 10 - 1; i 0; i--)
{
printf(%d , a[i]);
}
printf(\n);
例7.1:10元素一维数组倒序输出
初始化
在定义数组时对数组元素赋以初值。例如:
int a[10]={0,1,2,3,4,5,6,7,8,9};
将数组元素的初值依次放在一对花括弧内。
可以只给一部分元素赋值。例如:
int a[10]={0,1,2,3,4};
定义a数组有10个元素,但花括弧内只提供5个初值,这表示只给前面5个元素赋初值,后5个元素值为0。
如果想使一个数组中全部元素值为0,可以写成
int a[10]={0,0,0,0,0,0,0,0,0,0}; 或 int a[10]={0};
不能写成:int a[10]={0*10};
这是与FORTRAN语言不同的,不能给数组整体赋初值。
在对全部数组元素赋初值时,由于数据的个数已经确定,因此可以不指定数组长度。
例如:int a[5]={1,2,3,4,5}; 也可以写成 int a[]={1,2,3,4,5};
在第二种写法中,花括弧中有5个数,系统就会据此自动定义a数组的长度为5。但若数组长度与提供初值的个数不相同,则数组长度不能省略。例如,想定义数组长度为10,就不能省略数组长度的定义,而必须写成 int a[10]={1,2,3,4,5}; 只初始化前5个元素,后5个元素为0
例7.2 用数组来处理,求解Fibonacci数列
Fibonacci数列公式:已知: a1=a2=1, an=an-1+an-2 即:1,1,2,3,5,8,13……
int i;
int f[20]={1, 1};
for(i=2;i20;i++)
{
f[i]=f[i-2]+f[i-1];
}
for(i = 0; i 20; i++)
{
if(i%5 == 0)
{
printf(\n);
}
printf(%12d, f[i]);
}
使用冒泡排序,按升序排序
例7.3 假如有n个人,希望按年龄对他们进行排序
例7.3
input 10 numbers:
1 2 3 6 5 4 7 8 9 11
the sorted numbers:
1 2 3 4 5 6 7 8 9 11
int a[10];
int i,j,t;
printf(inpu
文档评论(0)