网站大量收购闲置独家精品文档,联系QQ:2885784924

6.4.1指针与二维数组-浙江长征职业技术学院.ppt

6.4.1指针与二维数组-浙江长征职业技术学院.ppt

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

6.4.1指针与二维数组 1、二维数组结构的分析 设有数组定义为:int a[3][4]; 则有: a表示数组在内存中的首地址。 a+i=a[i]=a[i][0] 代表第i行的首地址 浙江长征职业技术学院—计算机与信息技术系—相方莉制作 二维数组的逻辑结构图如下: a[0][3] a[0][2] a[0][1] a[0][0] a[1][3] a[1][2] a[1][1] a[1][0] a[2][3] a[2][2] a[2][1] a[2][0] a[0] a[1] a[2] a+0 a+2 a+1 6.4.1指针与二维数组 浙江长征职业技术学院—计算机与信息技术系—相方莉制作 【例6-16】输出二维数组有关值 #include stdio.h main( ) { int a[3][4]={0,1,2,3,4,5,6,7,8,9,10,11}; printf(%d,,a); //第0行首地址 printf(%d,,a[0]); //第0行0列地址 printf(%d\n,a[0][0]); //第0行0列地址 printf(%d,,a+1); //第1行首地址 printf(%d,,*(a+1)); //第1行0列地址 printf(%d,,a[1]); printf(%d\n,a[1][0]); } 6.4.1指针与二维数组 浙江长征职业技术学院—计算机与信息技术系—相方莉制作 【例6-17】用指针变量输出数组元素。 #include stdio.h main( ) { int a[3][4]={0,1,2,3,4,5,6,7,8,9,10,11}; int i,*p=a[0]; for(i=0;i12;i++,p++) { printf(%5d,*p); if ((i+1)%4==0) printf(\n); } } 6.4.1指针与二维数组 浙江长征职业技术学院—计算机与信息技术系—相方莉制作 6.4.2 指向指针的指针 如果一个指针变量存放的又是另一个指针变量的地址,则称这个指针变量为指向指针的指针变量。 定义格式: 类型标识符 **指针变量名 如:char **p; 浙江长征职业技术学院—计算机与信息技术系—相方莉制作 【例6-18】在例6-11的基础上,我们对源程序做以下修改。 #includestdio.h main( ) { static char *name[]={ Illegal day, Monday,Tuesday,Wednesday,Thursday, Friday, Saturday,Sunday}; char **ps; //定义一个指向字符指针变量的指针变量ps int i; printf(input Day No:\n); scanf(%d,i); if(i0) exit(1); ps=name+i; //为ps赋值 printf(Day No:%2d--%s\n,i,*ps); //输出 } 6.4.2 指向指针的指针 浙江长征职业技术学院—计算机与信息技术系—相方莉制作 name是一个指针数组,它的每一个元素是一个指针型数据,其值为地址。name是一个数组,它的每一个元素都有相应的地址。数组名name代表该指针数组的首地址。其中当i=1时,name[i]是Monday的首地址,ps=name+i是name[i]的地址,所以ps就是指向指针型数据的指针变量。输出时的“*ps”表示*(name+i),即name[i]。 6.4.2 指向指针的指针 浙江长征职业技术学院—计算机与信息技术系—相方莉制作 #include stdio.h #include math.h double f(double **x,int m,int n) { double max; int i,j; for(i=0;im;i++) { max=x[i][0]; for(j=1;jn;j++) if(fabs(x[i][j])fabs(max)) max=x[i][j]; for(j=0;jn;j++) x[i][j]/=max; } } void main() { FILE *fp; double a[3][3]={{1.3,2.7,3.6},{2,3,4.7},{3,4,1.27}}; double *c[3]={a[0],a[1],a[2]}; int i,j; /****考生在以下空白处写入执行语句*****

文档评论(0)

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

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

1亿VIP精品文档

相关文档