- 1、本文档共70页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C语言-数组ppt
第6章 数组 内容提要 数组定义和基本操作; 常用算法:求最大最小值、排序、查找等; 用字符数组存取字符串; 使用字符串处理函数处理字符串 为什么引入数组 保存大量同类型的相关数据 如矩阵运算,表格数据等 一维数组(Array)的定义 类型 数组名[长度]; 长度为常量表达式,不可以是变量(但C99提供了动态数组) 例:int a[10]; 定义一个有10个元素的数组,每个元素的类型均为int 使用a[0]、a[1]、a[2]、……、a[9]这样的形式访问每个元素。 系统会在内存分配连续的10个int空间给此数组 a就是此数组的首地址 一维数组(Array)的定义 类型 数组名[长度]; 长度为常量表达式,不可以是变量(但C99提供了动态数组) 例:int a[10]; 定义一个有10个元素的数组,每个元素的类型均为int 系统会在内存分配连续的10个int空间给此数组 a 是数组名,同时也代表着此数组的首地址 一维数组的初始化 int a[5] = {12, 34, 56, 78, 9}; int a[5] = { 12 }; int a[ ] = {12, 34, 56, 78, 9}; 一维数组的赋值 数组赋值和普通变量赋值一样 只能逐个对数组元素进行操作! 不能整体赋值! 切忌下标越界! 一维数组的输入和输出 耳听为虚,眼见为实 一维数组在内存中是连续存放的 一维数组名就是此数组首元素的地址 数组下标越界的严重性 证明:数组在内存中是连续分布的; 数组名就是数组的首地址 int i; int a[6]={1,3,5,7,9,11}; for (i=0; i=5; i++) printf(a[%d]的值是%2d,地址是%p\n, i, a[i], a[i]); printf(“a的size是%d\n”, sizeof(a)); printf(“a的值是%p\n”, a ); //a是数组名,也是首元素的地址 //a的值和a[0]的值相等 后果很严重!下标越界 int i, a[6]; for (i=1; i=6; i++) { a[i]=0; printf(a[%d]的值是%d\n,i, a[i]); } 数组的使用 数组的下标都是从0开始 对数组每个元素的使用与普通变量无异 可以用任意表达式作为下标,动态决定访问哪个元素 for (i=0; iSIZE; i++) a[i] = 2 * i; 下标越界是大忌! 使用大于最大下标的下标,将访问数组以外的空间。那里的数据是未知的,可能带来严重后果 sizeof可以用来获得数组大小 兔子繁殖问题(数组版) 兔子问题(数组版) #include stdio.h #define YEAR_MONTH 12 int main() { int f[YEAR_MONTH+1] = {0,1,1}; int month; for (month=3; month=YEAR_MONTH; month++) { f[month] = f[month-1] + f[month-2]; } for (month=1; month=YEAR_MONTH; month++) { printf(%d\t, f[month]); } retuun 0; } 反转并打印数组 求数组最小元素及其所在下标 #define N 10 ………………………… int i,a[N]; imin = 0; for (i = 1; i N; ++i) { if (a[i] a[imin]) imin = i; } printf(最小值是a[%d]:%3d\n,imin, a[imin]); 求数组最小元素及其所在下标 #include …… #define N 10 int main() { int i, imin, a[N]; srand(time(NULL)); for (i = 0; i N; ++i) { a[i] = rand ( ) % 100 ; printf(“a[%d]是: %3d \n , i, a[i] ) ; } imin = 0; for (i = 1; i N; ++i) { if (a[i]
您可能关注的文档
- (修改)幼儿园绿色生态园本特色课程的开发与实践研究结题报告.docx
- (全国100所名校单元测试示范卷)2016高三生物一轮复习备考-第五单元-《分子与细胞》综合检测(教师用卷).doc
- (冀教版)三年级科学上册课件-亲历科学-1.ppt
- (测验)有理数单元测试题-(一).doc
- (北师大版)一年级数学上册课件-10以内加减法练习课.ppt
- (苏教版)一年级数学上册-分与合练习题.doc
- (精品文档)坐井观天优秀课件PPT演示课件.ppt
- (译林版)四年级英语上册课件-Unit1-第一课时.ppt
- (苏教版)一年级数学上册课件-10的分与合.ppt
- -浅析部编义务教育语文教科书析一年级上册识字教学策略.docx
文档评论(0)