- 1、本文档共115页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第6讲 数组 C语言课件
6.1 一维数组的定义和引用 6.1.1 一维数组的定义 6.1.2 一维数组元素的引用 6.1.3 一维数组元素的初始化 6.1.4 一维数组应用举例 特别说明:在数组定义时,“常量表达式”外的方括号;以及元素引用时,“下标表达式”外的方括号,都是C语言语法规则所要求的,不是本书所约定的可选项的描述符号。 (4)数组元素的下标,是元素相对于数组起始地址的偏移量,所以从 0 开始顺序编号。 (5)数组名中存放的是一个地址常量,它代表整个数组的首地址。同一数组中的所有元素,按其下标的顺序占用一段连续的存储单元。 a 等价于 a[0]. (a已经不是一个变量,而是一个地址) 6.1.2 数组元素的引用 引用数组中的任意一个元素的形式: 数组名[下标表达式] 1.“下标表达式”可以是任何非负整型数据,取值范围是0~(元素个数-1)。 特别强调:在运行C语言程序过程中,系统并不自动检验数组元素的下标是否越界。因此在编写程序时,保证数组下标不越界是十分重要的. 6.1.2 数组元素的引用 2.一个数组元素,实质上就是一个变量,它具有和相同类型单个变量一样的属性,可以对它进行赋值和参与各种运算。 3.在C语言中,数值型数组不能作为一个整体参加数据运算,只能对单个的数组元素进行处理。 6.1.3 一维数组元素的初始化 初始化格式: 数据类型 数组名[常量表达式]={初值表} (1)如果对数组的全部元素赋以初值,定义时可以不指定数组长度(系统根据初值个数自动确定)。如果被定义数组的长度,与初值个数不同,则数组长度不能省略。 例: int a[]={1,3,5,7,9}; 6.1.3 一维数组元素的初始化 (2)“初值表”中的初值个数,可以少于元素个数,即允许只给部分元素赋初值。且没有赋值的元素值为0.如果没有赋值和初始化,则数组元素的值为不确定的数。(举例说明62.c) 例: int a[10]={1,2,3,4,5}; 则a[5]~a[9]都为0. (3)如果给一维数组赋值或输出,采用一层循环,用循环变量作为下标进行控制。 示例1(max.c):求数组元素的最大值 #includestdio.h main() { int i,a[10],max; for(i=0;i10;i++) scanf(%d,a[i]); max=a[0]; for(i=1;i10;i++) { if(a[i]max) max=a[i]; } printf(%d ,max); } 示例2(jiaohuan.c):交换数组元素,使第一个和最后一个交换,第二个和倒数第二个交换,依次类推。如数组为1,2,3,4,5,6,7,8,9,10,交换后为10,9,8,7,6,5,4,3,2,1(或者称为:逆置数组元素中的值) #includestdio.h main() { int i,a[10],t; for(i=0;i10;i++) scanf(%d,a[i]); for(i=0;i10/2;i++) {t=a[i];a[i]=a[10-1-i]; a[10-1-i]=t;} for(i=0;i10;i++) printf(%d ,a[i]); } 示例3(exp3.c):请补充函数fun,该函数的功能是:把数组aa中的偶数元素按原来的先后顺序放在原数组后面。例如,输入“33,67,42,58,25,76,85,16,41,56”,输出结果“33,67,25,85,41,42,58,76,16,56”。 #include stdio.h #define N 10 void fun(int aa[]) { int I, j=0,k=0; int bb[N]; for (I=0;IN; I++) {if ( ) bb[k++]=aa[I]; else aa[j++]=aa[I]; } for(I=0; ; I++,j++) aa[j]=bb[I]; } 示例4:排序问题用冒泡法对数组元素进行升序排序 对n个数进行排序的思路是: 如果要对n个数据排序,就需要进行n-1轮的比较,每次都对相邻两个数进行比较,将较大的数交换到后一个元素中。每一轮的比较都找出未排好的数据中的最大数放在这几个数的后面。 例如,第一轮需要比较n-1次,在n个数中找出最大数放在数组的最后一个元素中; 第二轮将对剩下的前n-1个数进行比较,需要比较(n-1)-1次,将前n-1个数中的最大者放入数组的倒数第二个元素中; ……以此类推,第n-1轮需要进行1次比较,将剩下的2个数中的较大者放入a[1
您可能关注的文档
- 第6章 热电式传感器 《传感器技术与应用》课件.ppt
- 第6章 激励理论与管理(下) 管理心理学 教学课件.ppt
- 第6章 燃气管网的水力计算 燃气输配 教学课件.ppt
- 第6章 特许经营体系中的产品质量风险及其控制 特许经营导论 教学课件.ppt
- 第6章 滤镜组 After Effects CS4影视后期设计与制作 教学课件.ppt
- 第6章 生产和服务设施布置 《生产与运作管理》课件.ppt
- 第6章 生产和服务设置运作管理.ppt
- 第6章 电磁波辐射 电磁场理论.pdf
- 第6章 程序流程概述 C++教学用PPT 教学课件.ppt
- 第6章 空气射流及燃料燃烧时的热质交换原理与设备 热质交换原理与设备 教学课件.ppt
最近下载
- 2024《小米公司手机品牌营销环境SWOT分析及营销策略》10000字.docx
- 4节 学校体育与学生动作发展.pdf
- 海康威视VisionMaster算法平台用户手册V2.2.pdf
- 石秀峰-数据治理-企业数字化转型必经之路-2022.3.19.pdf VIP
- 某大学综合体育馆项目可行性研究报告.doc VIP
- 幼儿园大班音乐《光脚的小约翰》活动课件.pptx
- 三校生计算机基础知识提纲及讲义资料.docx
- 三年级音乐学情及教材分析集合6篇 .pdf VIP
- 九年级化学下册教学课件《跨学科实践活动9 探究土壤酸碱性对植物生长的影响》.pptx VIP
- 大疆 大疆智图 操作白皮书.pdf VIP
文档评论(0)