- 1、本文档共46页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
C语言第十二次课
* #include stdio.h swap(int *p1, int *p2) { int *p; *p=*p1;*p1=*p2;*p2=*p; } void main() { int a,b,*q1,*q2; scanf(%d,%d,a,b); q1=a; q2=b; if(ab) swap(q1,q2); printf(%d,%d\n,a,b); } p2 q1 5 2 a b 2000 2002 2004 2006 2008 2010 2012 2002 p1 2000 q2 2000 2002 p 指针与函数 xx ? * 例 int a[5]; int *p; p=a[0]; a[0] a[1] a[2] a[3] a[4] p a[0] 数组名是一个地址常量 它的值是数组的首地址 指针与数组 或 int *p=a[0]; 或 int *p=a; 2000 p+1 ? 2000 2002 2004 2006 2008 2010 2012 * 若p指向int数组,则p+1?p+1?2 例 p=a[0]; 则 p+1= 例 int *p=a[2]; p++; *p=1; 指针与数组 a[0] a[1] a[2] a[3] a[4] 2000 2002 2004 2006 2008 2010 2012 a[1]=2002 p=2000 p=2004 2000 1 则 a[?]=1 3 * 若p指向int数组,则p+1?p+1?2 例 int a[5]; int *p1=a[1]; int *p2=a[4]; 则 p2-p1= ? 指针与数组 a[0] a[1] a[2] a[3] a[4] 2000 2002 2004 2006 2008 2010 2012 p1=2002 p2=2008 3 p1+p2 ? * p=a; p?i?变量p的值?i?每元素所占字节数 p1-p2=两指针之间元素的个数 p1+p2无意义 指针与数组 将数组的首地址?p p=a[i]; 将某数组元素的地址?p * p++,p--: 使p后移或前移一个存储单元 *p++, *(p++):先取p所指对象*p,再使p后 移一个单元 *(++p): 先使p后移一个存储单元,再 取p所指对象*p (*p)++: 先取p所指对象的值,再使该 对象的值加1 指针与数组 * #include stdio.h void main() { int a[]={0,10,20,30,40,50,60}; int x=5,*p; p=a+2; x+=*(p++); printf(\nx=%d,x); x-=(*p)++; printf(\nx=%d,x); x*=*(++p); printf(\nx=%d,x); x/=++*(p); printf(\nx=%d,x); } 答案: x=25 x=-5 x=-200 x=-4 31 41 练 习 * 指针与数组 2000 2002 2004 2006 2008 2000 a a+1 a+2 a+3 a+4 *a *(a+1) *(a+2) *(a+3) *(a+4) a[0] a[1] a[2] a[3] a[4] 数组地址 数组元素 p p+1 p+2 p+3 p+4 *p *(p+1) *(p+2) *(p+3) *(p+4) p[0] p[1] p[2] p[3] p[4] 若p=a[0],则p=a a[i] ? p[i] ? *(p+i) ?*(a+i) * 例 数组元素的引用方法 #include stdio.h void main() { int a[5],*pa,i; for(i=0;i5;i++) a[i]=i; pa=a; for(i=0;i5;i++) printf(*(pa+%d):%d\n,i,*(pa+i)); for(i=0;i5;i++) printf(*(a+%d):%d\n,i,*(a+i
文档评论(0)