网站大量收购闲置独家精品文档,联系QQ:2885784924

信息学奥林匹克竞赛C语言课程胶片4-定向改编V1.0解读.pptx

信息学奥林匹克竞赛C语言课程胶片4-定向改编V1.0解读.pptx

  1. 1、本文档共54页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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)

shuwkb + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档