二维数组概述与应用15课件讲解.pptxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

二维数组概述与应用

什么是二维数组?二维数组的基本概念可以想象成表格或矩阵,有行和列两个维度每个元素需要通过两个下标来定位:row(行)和col(列)可以看作是一维数组的数组,每个一维数组对应二维数组中的一行例如:二维数组存储3个学生的4门课程的成绩,每个学生的每门课程成绩都可以通过行和列两个下标来定位二维数组的直观表示9085927888768095intscores[3][4];3个学生×4门课程=12个元列[0][0][1][1][2][2][3]

二维数组的定义与结构定义语法类型名数组名[行数][列数];例如:intscores[3][4];下标使用方法通过两个下标访问元素:scores[行][列]下标从0开始计数第1个学生的第1门课成绩存储在scores[0][0]中二维数组可看作是由多个一维数组组成:第123存存储特点C语言中,二维数组在内存中是连续存储的采用行优先的存储方式:先存储第1行的所有元素,再接着存储第2行,依此类推这样的存储方式保证了数组元素在内存中连续,便于计算机高效访问二维数组在内存中的存储方式908592788876809575826888第1行第2行第3行如图所示,二维数组按照行优先顺序存储,每个元素占用4个字节(int类型)访问元素scores[i][j]的内存地址计算公式:基址+(i×列数+j)×元素大小

二维数组在内存中的存储方式内存存储特点C语言中,二维数组在内存中是连续存储的采用行优先的存储方式:先存储第1行的所有元素,再接着存储第2行,依此类推这样的存储方式保证了数组元素在内存中连续,便于计算机高效访问行优先存储的意义提高缓存命中率,加速数据访问便于按行处理数据的场景简化了内存分配和索引计算二维数组的内存存储方式intscores[3][4]0][0][0][1][0][2][0][3][1][0][1][1][1][2][1][3][2][0][2][1][2][2][2][3]存储过程1存储第1行所有元素2存储第2行所有元素3存储第3行所有元素内存优势元素在内存中连续,便于计算机高效访问按行优先存储保证了局部性原理,提高缓存命中率简化了内存分配和索引计算C语言二维数组:概念、定义与应用4/119085927888768095

二维数组的初始化方法二维数组的初始化和一维数组类似,可以在定义时给各个元素赋初值。以下是四种常见的初始化方法:按行初始化将每行的元素括起来,依次写出。层次清晰,每行对应什么数据一目了然。intscores[3][4]={{90,85,92,78},{88,76,80,95},{75,82,68,88}};连续初始化不分层次,直接将所有元素按顺序写在一个括号里。编译器会按照行优先的顺序将这些数值依次填入数组。intscores[3][4]={90,85,92,78,88,76,80,95,75,82,68,88};部分初始化只对数组的部分元素赋初值,剩下的元素编译器会自动初始化为0。适用于只需要部分初始化的场景。intscores[3][4]={{90,85},{88},{75,82,68}};//未赋值的元素自动初始化为0省略行数在初始化时,可以省略行数,编译器会根据初始化的数据自动推断行数。列数不能省略。intscores[][4]={{90,85,92,78},{88,76,80,95},{75,82,68,88}};//编译器根据初始化数据推断有3行初始化要点初始化必须在定义时进行未赋值的元素自动初始化为0行数可以省略,列数不能省略初始化数据不能超过数组大小

二维数组的应用:学生成绩计算问题描述3名学生,每名学生参加了4门课程的考试,计算每名学生的平均成绩。解决方案使用二维数组scores[3][4]存储学生成绩通过嵌套循环计算平均分外层循环遍历每个学生(行)内层循环遍历该学生的每门课程(列)计算总分并求平均值实现思路1.定义二维数组scores[3][4]存储成绩2.外层循环遍历每个学生(行)3.内层循环遍历该学生的每门课程(列)4.计算总分并求平均值学生成绩表908592788876809575826888intscores[3][4];嵌套循环处理过程1sum=02sum+=scores[i][j]3average=sum/490859278例如:计算第一个学生的平均成绩外层循环控制学生索引(i)i=0到2内层循环控制课

文档评论(0)

vermonth134 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档