第5章 利用数组处理批量数据.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第5章利用数组处理批量数据解读

第5章 利用数组处理批量数据 5.1数组的作用 1.数组: 一组有序的相同类型变量的集合 2.数组元素可以用数组名结合下标表示 3.数组的维数: 一个数组元素下标的个数 4.数组类型: 数组元素的类型 5.下标的下界: 0 6.下标的上界: 长度 - 1 5.2一维数组 5.2.1 定义一维数组 格式 数据类型 数组名[常量表达式] ; 说明 常量表达式为第一维的长度(元素的个数) 例 int a , b[10] , c[20] ; 提示: 一个数组中的所有元素依下标由小到大的顺序占据连续的内存空间。 5.2.2 引用(表示)一维数组元素 格式 数组名[下标表达式] ; 例 b[0] , b[1] , b[i] , c[2] , c[m] 例题5.1:给数组元素a[0]~a[9]赋值0~9,然后按逆序输出。(121页) 程序代码 #includestdio.h void main() { int i,a[10]; for(i=0;i=9;i++)a[i]=i; for(i=9;i=0;i--)printf(%d ,a[i]); puts(); } 5.2.3 一维数组(元素)的初始化 (1)定义数组时,对所有元素赋初值 例 int a[3]={18,-10,100}; (2)定义数组时,允许给前一部分元素赋初值。未赋初值的元素值为0 例 int a[6]={18,-10,100}; (3)使一个数组的所有元素值为0(122页) (4)若定义数组时为所有元素赋初值,可以省略长度 如 int a[3]={18,-10,100}; 可以 简写为 int a[ ]={18,-10,100}; 5.2.4 一维数组的典型算法-递推与排序 例题5.2:显示Fibonacci数列前20项,每行5项。(122页) 关键点: f[i]=f[i-2]+f[i-1] 程序代码 #includestdio.h void main() { int i,f[20]={1,1}; for(i=2;i20;i++)f[i]=f[i-2]+f[i-1]; for(i=0;i20;i++) { printf(%12d,f[i]); if((i+1)%5==0)puts(); } puts(); } 例题5.3:用冒泡法对10个数按升序排序。(123页) 关键点: 用冒泡法将a[0]到a[9]升序排序的思路为: 逐次确定a[9]、a[8]、…、a[9-i]、…、a[1],其中i从0取到8。确定a[9-i]的思路是: 从a[0]到a[9-i]逐对比较,若不满足前后关系(即a[j]a[j+1]),则交换;其中j从0逐次取到8-i。 程序代码 #includestdio.h void main() { double a[10],t; int i,j; puts(请输入10个数,相邻的数据用空白符分隔:); for(i=0;i10;i++) scanf(%lf,a[i]); puts(); for(i=0;i9;i++) for(j=0;j9-i;j++) if(a[j]a[j+1]) t=a[j],a[j]=a[j+1],a[j+1]=t; puts(排序的结果:); for(i=0;i10;i++) printf(%.2f ,a[i]); puts(); } 5.3二维数组 5.3.1 定义二维数组 格式 数据类型 数组名[常量表达式1] [常量表达式2] ; 说明 常量表达式1为第一维的长度,常量表达式2为第二维的长度 例 int a , b[10] , c[20] , d[3][10] , e[5][20] ; 提示: 一个数组中的所有元素依下标由小到大的顺序占据连续的内存空间。 5.3.2 引用(表示)二维数组元素 格式 数组名[下标1表达式] [下标2表达式] ; 例 d[1][3] , d[i][j] , e[m][n] 5.3.3 二维数组程序举例 例题5.4:将一个2×3的矩阵a转置的结果保存到b中。(126页) 程序代码 #includestdio.h void main() { int a[2][3]={{1,2,3},{4,5,6}},b[3][2],i,j; puts(矩阵a如下:); for(i=0;i2;i++) { for(j=0;j3;j++) { printf(%5d,a[i][j]); b[j][i]=a[i][j]; } puts(); } puts(转置矩阵如下:); for(i=0;i3;i++) { for(j=0;j2;j++) printf(%5

文档评论(0)

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

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

1亿VIP精品文档

相关文档