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

整型指针与数组.ppt

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

整型指针与数组 辽宁科技大学 黄建 mtysoft@163.com 指针定义及引用 指针与变量2-1 指针与变量2-2 两个指针变量2-1 两个指针变量2-2 习题演练 数组与地址 数组恒等式 指针与数组 指针是数组 指针自增 指针与自增8-1 指针与自增8-2 指针与自增8-3 指针与自增8-4 指针与自增8-5 指针与自增8-6 指针与自增8-7 指针与自增8-8 地址自增比较 地址与自增小结 为指针变量赋初值 int a = 3, *p; p = a; 课后题:求二维数组行列之和 把二维数组a各行之和分别放入b数组,各列之和分别放入c数组。 * * int a, *p; a = 3; 3 2000 a p 2000 printf(a = %d, *p = %d, a, *p); a = 3, *p = 3 取地址 取值 指针变量 p = a; int a, *p; a = 3; p = a; 3 2000 a p 2000 printf(a = %d, *p = %d, a, *p); a = 4, *p = 4 4 a = 4; int a, *p; a = 3; p = a; 3 2000 a p 2000 printf(a = %d, *p = %d, a, *p); a = 4, *p = 4 4 *p = 4; int a=3, b=4; int *p, *w; p = a; w = b; 3 2000 a p 2000 printf(%d,%d,%d,%d, a,b,*p,*w); 4,4,4,4 4 *p = *w; 4 3000 b w 3000 int a=3, b=4; int *p, *w; p = a; w = b; 3 2000 a p 2000 printf(%d,%d,%d,%d, a,b,*p,*w); 3,4,4,4 p = w; 4 3000 b w 3000 3000 int a=1, b=3, c=5; int *p, *w, *s; p=a, w=b, s=c; 1 a p 5,9,2,9,5,9 3 b w 5 c s (*p)++; 2 *w=*p, *p=*s, *s=*w; 2 5 2 s=w, w=p, p=s; *p = *w + *s + b; 9 1 2000 3 5 2004 2008 a[0] a[1] a[2] =2000 a 数组代表类型相同、连续存放 连续 数组名代表地址 地址 数组名代表常量 常量 for (i = 0; i 3; i++) 1 2000 3 5 2 0 1 a 2004 2008 printf(%d,, a[i]); *(a+i) =2000 数组恒等式: a[i] = *(a+i) for (i = 0; i 3; i++) 1 2000 3 5 2 0 1 a 2004 2008 printf(%d, =2000 p p = a; , a[i]); , p[i]); *(p+i) 指针就是数组 数组名是指针 指针是地址 1 2000 3 5 2 0 1 a 2004 2008 printf(%d, p[0]); =2000 p p = a + 1; printf(%d, *(p+0)); printf(%d,%d, p[1], p[-1]); 1 2000 3 5 2 0 1 a 2004 2008 for (i = 0; i 3; i++) =2000 p p = a; { printf(%d, *p); p++; } printf(%d, *p++); p p p 2012 p[i] *(p+i) a[i] *(a+i) *a++ 数组名代表常量 常量 1 3 0 1 a p p = a; k = *p++; p k=1, *p=3, a[0]=1, a[1]=3 = k = *(p++); 右结合 1 k = k=*p, p++; 1 3 0 1 a p p = a; k = *++p; p k=3, *p=3, a[0]=1, a[1]=3 = k = *(++p); 右结合 3 k = ++p, k=*p; 1 3 0 1 a p p = a; k = (*p)++; k=1, *p=2, a[0]=2, a[1]=3 1 k = k=*p, (*p)++; 2 1 3 0 1 a p p = a; k = ++(*p); k=2, *p=2, a[0]=2, a[1]=3 2 k = ++(*p), k=*p; 2 1 3 0 1 a p p = a; k = ++(*p++); k=2, *p=3, a[0]=2, a[1]=3 2 k = ++(*p), k=*p, p++; 2 p 1

文档评论(0)

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

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

1亿VIP精品文档

相关文档