




已阅读5页,还剩42页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第七章数组:数组是一种构造类型,元素由基本类型(整体、实体和字符)组成。它是同类数据的有序集合。7.1一维数组的定义和参考7.1.1一维数组的定义形式:类型说明符数组名常量表达式如:inta5;10;描述:1。命名规则:数组名由合法的标识符组成。数组名由括起来。常量表达式包括整数、字符和符号常量表达式。例如:inta 23,b 5,c a,_ d 8,XYZ # (#=35) #定义5 main() intan;printf(%dn ,a1=100);还有:INTA (10),10,5%,8%,50%,5X 100对吗?另一个例子:inti=5;英塔是正确的吗?3.数组长度INTA50,1,2,3,4 5个元素,下标从0到4。注意:可以引用涡轮中超出定义数组下标的元素,系统不会检查。Cmin () inti,a5;对于(I=0;I=4;I)printf(“a% d=% d n”,I,aI=I 1);printf(a5=%dt ,a5);printf(a6=%dn ,a6);,运行结果:A0=1A1=2A2=3A3=4A4=5A5=-30A6=285,4。数组大小的定义只能是常量,不能是变量或动态定义的。Cmin () intn=5,an;a1=100;printf(“a1”=% d n,“a1”);编译指出:constantexpressionrequireddinfunctionmain(主函数需要常量表达式),7.1.2一维数组元素的引用规则:1。使用前定义。2.引用形式:数组名下标下标可以是常量、变量或表达式的整数或字符类型。3.引用方法:对于元素,而不是整个数组。例如:0=2-96-3-2-2例T7-1。C顺序评估数组A,并以相反的顺序输出main()inta5,I;对于(I=0;I=0;I-)printf(“a% d=% d n”,I,aI);,运行结果:A 4=4A 3=3A 2=2A 1=1A 0=0,7.1.3一维数组的初始化通过:1实现。定义过程中数组元素的初始化如下:inta5=1,2,3,4,5 ;2.仅给某些元素赋值,如inta5=1,3,5 ;3.在初始化期间为所有元素分配0值,例如:INTA5= 0,0,0,0,0 ;或inta5= 0 ;4.当给所有元素分配初始值时,可能不指明长度,例如:inta5=2,4,6,8,10 ;或inta=2,4,6,8,10 ;效果是一样的。例如,T7-1-1.c初始化main() inti;inta5=2,4,6,8,10 ;对于(I=0;I=4;I)printf(“% d n”,aI);注意:静态存储类别,符合新的ANSI标准。如果采用静态,数组元素的值存储在静态区域。结果:246810,7.1.4一维数组程序示例T7-2.c斐波那契数列问题关于斐波那契算法:前两个数各为1,其后的每个数都是前两个数的和。main() inti;intf20=1,1 ;对于(I=2;i20I)fI=fI-2fI-1;对于(I=0;i20I) if(I % 5=0)printf( n );printf(d,fi;在这种情况下,T7-3.c使用冒泡方法对6个数字进行排序(从小到大)。思路:成对地比较两个相邻的数字。如果数字很小,就应该转移到前面,同时比较数字。在这种情况下,n=6。外循环j(1n-1)内循环i(1n-j),988888,895555,559444,444922,222290,000009,85555,58444,44822,22280,00008,5444,4522,2250,0005,422,240,004,20inti,j,t;printf( input 6 numbers 3360 n );对于(I=1;(一世) t=a一世;aI=aI 1;aI=t; printf( theortednumbers : n );对于(I=1;i7;i )printf(%d_ ,aI);2.1二维数组的定义和参考7.2.1二维数组的定义1 .一般形式:类型说明符数组名常量表达式常量表达式例如,flower34定义数组a在c中有三行四列。二维数组可视为一维数组的一种特殊形式。上面的定义可以看作是一个有三个元素的一维数组,每个元素可以看作是一个有四个元素的一维数组。因此,上述定义相当于:浮动04,14,24注:如果在实际应用中如此定义,将被视为重新定义。2.二维阵列的每个元素在存储器中的存储顺序如下:它以第一列和第二列的顺序存储,例如T7-3-1。Cmin () inti,j,a23;对于(I=0;I2;I)对于(j=0;J3;j)扫描( %d ,输入:1357911输出:浮动23,k;对于(I=0;I2;I)对于(j=0;J3;j )scanf(%f ,对于(j=0;J3;J) ScanF (%f% f ,总共24个元素,在内存中按顺序排列:第三维度变化最快,然后是第二维,第一维最慢。7.2.2二维数组的引用形式:数组名下标下标,其中:下标是常量、变量或整数或字符类型的表达式。(变量不能用于定义)例如,121j1。数组元素可以出现在表达式中,例如12=22/22。使用数组元素时,应注意不要超出它们的定义范围;例如:23;a23=5;7.2.3二维数组1的初始化。按行将初始值分配给二维数组,例如inta23=1,2,3,4,5,6 ;2.根据数组元素的顺序分配初始值,例如:inta23=1,2,3,4,5,6 ;3.通过线条为某些元素指定初始值是很直观的,例如inta23=2,5, 3 ;4。当给所有元素赋值时,第一维下标可以省略,例如:inta3=1,2,3,4,5,6 ;另一个例子是:inta4=0,0,3,0,0,10 ;例如,T7-4交换二维数组的行和列元素,并将它们存储在另一个二维数组中。T7-4.c两个行和列的数组交换main () INTA 2 3=1,2,3,4,5,6 ;32,我,j;printf( array : n );对于(I=0;I=1;I)对于(j=0;j=2;j) printf(“M”,aIj);bjI=aIj; printf( n ); printf(“array : n”);对于(I=0;I=2;I)对于(j=0;j=1;(j )printf(M ,b .Ij);printf( n );在示例T7-5c中有34个矩阵,并且行号和列号main()inti,j,r=0,c=0,最大值;inta34=1,2,3,4,9,8,7,6,-10,10,-5,2 ;max=a00;对于(I=0;j;r=i。c=j printf(“max=% d,row=%d,colum=%dn”,max,r,c);,运行结果:最大值=10,行=2,列=1问题:为什么在比较前应将00分配给最大值?7.3字符数组字符数组:用于存储字符数据。一维字符数组:存储一个字符串(每个数组元素一个字符),二维字符数组:存储多个字符串(行数是字符串的个数)。7.3.1字符数组的定义形式:字符数组名常量表达式字符数组名常量表达式常量表达式常量表达式:整数、字符、符号常量。例如:查拉5;一个0= C ;一个1= H ;一个2=“我”;3= N ;一个4=“一个”;7.3.2字符数组初始化:字符5=C , H , I , N , A ;charb5=C , H , I , N , W , U ;在编译时,将会指出有太多的初始化值Charc 5=c , h , I ;查德= c , h , I , n , a系统自动确认5,7.3.3字符数组的参考示例T7-6.c输出字符串main()查德10= I , _ , a , m , _ , h , a , p , p , y ;inti对于(I=0;i10I)printf(“% c”,cI);打印( n );运行结果:我很开心,T7-7。C输出DIA图MAIN() CHARDIUM5= , * , ,*, * , * , * , * ;intiintj对于(I=0;i5;I)对于(j=0;j5;j)printf(“% c”,钻石Ij);printf( n );、7.3.4字符串以及字符串结束标记的几种描述:(1)字符串:用双引号括起来的几个字符,可以存储在一维或二维字符数组中。(2)字符串的结束标记是:“ 0”(既不是动作也不是显示)(3)字符串的长度:第一个“ 0”之前的字符数。(4)如果在字符数组或字符串中遇到“ 0 ”,则认为该字符结束;(5)字符串可以初始化字符数组,如:CHARC= 我_ AM _ HAPPY ;系统自动在数组末尾添加 0 ,长度为11或CHARC=我_我_高兴;系统会在数组末尾自动添加长度为11的“ 0”,相当于c =I , _ , a , m ,_ , h , a , p , p , y , 0 ;Charc 10=“中国”注意:字符“ 0”不总是在字符数组之后,并且在输出期间遇到第一个“ 0”结尾;示例T7-7-1。CMAIN () CHARA =A , B , 0 , 1 , 2 ;charb= ab 0cd ;printf(%sn%sn ,a,b);运行结果:abab,7.3.5字符数组1的输入和输出。字符数组的输出:示例T7-7-2 . cmain() inti;查拉10=“中国”;charb18=“中国 0中国 0中国”;对于(I=0;i10I)printf(“% c”,aI);printf( n );printf(%sn ,a);对于(I=0;I字符串2返回值为正,其值为Ascii差值(3)字符串1字符串2返回值为负,其值为Ascii差值,例如T7-7-8。Cmin () INTI,J,K;chara1=“武汉”,a2=“北京”;i=strcmp(a1,a2);j=strcmp(中国、韩国);k=strcmp(a2,“北京”);printf(i=%dnj=%dnk=%dn ,I,j,k);注意:“=”运算符不能用于比较两个字符串。虽然编译没有错误,但结果是不正确的。运行结果是:I=21I=W-B=119-98=21J=-8J=C-K=99-107=-8K=0K=B-B=98-98=0.6。查找字符串长度的函数形式:strlen(字符数组)函数:检测字符串长度,返回字符串长度值,不包括 0 ;Cmin () chara1 10=“中国”;printf(%dn ,strlen(a1);printf(%dn ,strlen(北京 0武汉);,运行结果:57,7。大写和小写字母转换函数:strlwr(字符串)8。小写大写字母转换函数:strupr(字符串)示例T7-7-10。cmain () chara1 6=“中国”,a2 =“武汉”;printf(%sn ,ST rlwr(a1);printf(%sn
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年事业单位工勤技能-湖南-湖南保健按摩师三级(高级工)历年参考题库含答案解析
- 2025年事业单位工勤技能-湖北-湖北水生产处理工一级(高级技师)历年参考题库含答案解析
- 生鲜电商“最后一公里”配送时效性研究报告
- 中药配方颗粒行业标准与市场竞争格局研究报告
- 2025-2030中国红木市场供应渠道及应用前景趋势预测报告
- 2025年环保设备市场细分领域竞争与创新驱动因素研究报告
- 探究2025年绿色供应链管理在建筑材料制造业的应用与推广策略报告
- 2025年事业单位工勤技能-河南-河南殡葬服务工四级(中级工)历年参考题库典型考点含答案解析
- 2025年事业单位工勤技能-河南-河南家禽饲养员一级(高级技师)历年参考题库典型考点含答案解析
- 2024版培训教室出租协议
- 企业员工职业道德考核制度
- 公司安全事故隐患内部举报、报告奖励制度
- 【初中物理】质量与密度练习题 2024-2025学年初中物理人教版八年级上册
- 南外初中小语种课程设计
- 【上海市塑料探究所企业员工激励机制存在的问题及优化建议探析(论文)8200字】
- Unit2 Whats your hobby-教案人教精通版英语六年级上册
- 【必刷题】2024五年级英语上册一般过去时专项专题训练(含答案)
- T-CTSS 86-2024 原味茶饮料标准
- NB-T 10436-2020 电动汽车快速更换电池箱冷却接口通.用技术要求
- 简易财务报表附注模板
- 电梯安全总监和安全员的任命文件
评论
0/150
提交评论