- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
[理学]C语言第5章_数组课件
第5章 数组 本章要点 一维、二维数组的定义、引用和初始化 一维、二维数组的应用 字符数组及其应用 主要内容 一维数组的定义和引用 二维数组的定义和引用 数组与循环计算 C语言的数据类型: 为何引进数组? 若干问题 一个班学生的学习成绩的统计 文本的处理 矩阵的运算 数据的排序 上述问题中数据有何特点,如何存储? 特点 每个数据元素具有相同的数据类型。 使用过程中需要保留原始数据。 存储:需要同时存储所有的数据元素,按一定顺序存储。 数组:一组具有相同数据类型的数据的有序集合。 数组中的每个元素属于同一个数据类型。 用一个统一的数组名和下标来唯一地确定数组中的元素。 一维数组的定义(5.5.1) 定义格式 类型说明符 数组名[常量表达式]; 如:int a[6]; 一维数组的初始化 (5.1.2) 数组的初始化指在定义数组时对数组元素赋初值。 初始化方式: 类型说明符 数组名[常量表达式]={初值列表} 如:int a[5]={1,2,3,4,5}; ? a[0]=1; a[1]=2; a[2]=3; a[3]=4; a[4]=5; 可以只给部分元素赋值 如: int a[5]={6,2,3}; ? 只初始化前3个元素,后2个元素为0。 初始化的数据个数不能超过数组大小: 如: int a[3]={6,2,3,5,1}; 一维数组的初始化 (5.1.2) 当全部数组元素赋初值时,可不指定数组长度 如:int a[ ]={1,2,3,4,5} ? int a[5]={1,2,3,4,5} 而:int a[10]={1,2,3,4,5} ? 只初始化前5个元素,后5个元素为0。 对所有数组元素赋相同的初值时,可写成 int a[6]={5,5,5,5,5,5} 不能写成 int a[6]={5*6}或int a[6]=5 一维数组的引用 (5.13) 数组元素的表示形式: 数组名[下标] 其中,下标可以是整型常量或整型表达式。 如:int a[6], i=1; a[0]=a[3]+a[2*i-1]; 注意: 数组必须先定义,后使用。 C语言对数组不作越界检查,使用时要注意。 只能逐个引用数组元素,不能一次引用整个数组。 数组元素相当于一个同类型的变量。 例 数组元素的引用 注意数组定义与引用的错误用法 一维数组程序举例 例 利用数组求Fibonacci数列的前20个数。 Fibonacci数列:1,1,2,3,5,8,13,21…… 递推公式:f1=1; f2=1; fn=fn-1+fn-2, n≥3 一维数组程序举例 例1 有10个学生的成绩,求平均分。 92 85 68 75 54 88 98 45 61 79 一维数组程序举例 例2 读个n整数存入数组,找出其中最大值和最小值。 一维数组程序举例 例 冒泡排序:用冒泡法对n个数由小到大排序。 折半查找 算法原理 前提:数组中的数据已经按顺序排列(可升序或降序) 设置三个脚标: left表示查找区间的起始元素的下标; right表示查找区间的末尾元素的下标; mid表示查找区间的中间元素的下标;mid=(left+right)/2 初始状态:left=0,right=n-1; 查找过程有三个状态: 1.若x==a[mid],则找到了; 2.若xa[mid],说明数据可能在a[mid+1]~a[right]间,令left=mid+1; 3.若xa[mid],说明数据可能在a[left]~a[mid-1]间,令right=mid-1; 查找33 查找15 #includestdio.h void main() { int a[10]={7,9,12,18,21,25,33,39,45,60}; int x,left=0,mid,right=9,flag=0; clrscr(); printf(shuru:\n); scanf(%d,x); if(x=a[left]x=a[right]) while(flag==0left=right) { mid=(left+right)/2; if(a[mid]==x) flag=1; else if(a[mid]x) right=mid-1; else left=mid+1; } 例5.9 将以为数组中元素向左循环移位,移位次
您可能关注的文档
最近下载
- 2025贵州黔西南州畅达交通建设运输(集团)有限责任公司招聘10人笔试备考试题及答案解析.docx VIP
- 美容培训课件抗衰老ppt.pptx VIP
- 青溪无菌线考试试卷—无菌线岗位.docx VIP
- 医用吊塔(国产).pptx VIP
- T_HSQTA 002-2023_太平魁红茶_标准.pdf VIP
- 2025年治愈心理测试题及答案.doc VIP
- 医疗保险门诊特殊疾病申请表(异地).doc
- IPC-6012F 2023 EN,刚性印制板性能要求Qualification and Performance Specification for Rigid Printed Boards.pdf VIP
- N市公安机关涉警网络舆情处置问题研究.pdf VIP
- 全厂起重机电气设备安装施工方案.doc VIP
文档评论(0)