欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    第10章 指针,c语言.ppt

    • 资源ID:82870286       资源大小:354KB        全文页数:70页
    • 资源格式: PPT        下载积分:16金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要16金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    第10章 指针,c语言.ppt

    第十章第十章 指指 针针掌握指针与指针变量的概念;掌握指针与指针变量的概念;掌握数组的指针和指针数组的使用;掌握数组的指针和指针数组的使用;掌掌握握字字符符串串指指针针和和指指向向字字符符串串的的指指针针变变量的使用;量的使用;掌握指针函数和函数指针的使用;掌握指针函数和函数指针的使用;了解指向指针的指针的概念及其使用。了解指向指针的指针的概念及其使用。预预 备备 知知 识识内存:内存:就是内部存储器,是由存储单元组成 的。它的特点是存储单元是线性连续 的。存储单元的最小单位是字节。1.内存的概念内存的概念地址:地址:为了访问内存中的某个存储单元,我们 要为它编号,这种编号称为内存地址。通过地址我们就能够访问该地址所标 识的存储单元。2.地址的概念地址的概念变量的地址:变量的地址:变量在内存中总占用几个连续的变量在内存中总占用几个连续的 字节,开始字节的地址,就是变量的地址。字节,开始字节的地址,就是变量的地址。20072007存储单元10.1 10.1 指针及其相关概念指针及其相关概念 指针:指针:一个变量的地址称为该变量的指针。一个变量的地址称为该变量的指针。指针变量:指针变量:若一个变量专用于存放另一个变量若一个变量专用于存放另一个变量 的地址(指针),则该变量称为指针变量。的地址(指针),则该变量称为指针变量。指针的对象:指针的对象:当把变量的地址存入指针变量后,当把变量的地址存入指针变量后,我们就可以说我们就可以说这个指针指向了该变量这个指针指向了该变量。变量的存取方法:变量的存取方法:直接存取和间接存取。直接存取和间接存取。直接存取:直接存取:直接根据变量名存取数据。直接根据变量名存取数据。间接存取:间接存取:通过指针变量存取相应变量的数据通过指针变量存取相应变量的数据。10.2.2 变量的指针和指向变量的指针变量变量的指针和指向变量的指针变量一、指针变量的定义一、指针变量的定义 一般形式:一般形式:类型标识符类型标识符 *变量名变量名 ;例如:int*ptr1,*ptr2;指针变量的类型:指明了该指针指向的内存空指针变量的类型:指明了该指针指向的内存空 间所存储的数据类型。间所存储的数据类型。在定义指针变量时要注意以下几个问题在定义指针变量时要注意以下几个问题:变量名变量名ptr2前面的前面的“*”不能省略,如果写成不能省略,如果写成 int*ptr1,ptr2;则则ptr2被定义为整型变量,而非整型指针变量。被定义为整型变量,而非整型指针变量。定义中的定义中的“*”表示所定义的变量是指针变量,但表示所定义的变量是指针变量,但 指针变量名是指针变量名是ptr1、ptr2,而非而非*ptr1、*ptr2。指针变量只能指向定义时所规定类型的变量。指针变量只能指向定义时所规定类型的变量。这个规定的类型称为该指针变量的这个规定的类型称为该指针变量的“基类型基类型”。如:上例中ptr1、ptr2只能指向整型变量,不 能指向实型或字符型变量。其“基类型”相同,都是整型。定义指针变量后,并未确定该变量指向何处。定义指针变量后,并未确定该变量指向何处。也就是说该变量的值是不确定的。在引用指针也就是说该变量的值是不确定的。在引用指针 变量前必须首先让它指向一个变量,这一点非变量前必须首先让它指向一个变量,这一点非 常重要。常重要。二、指针变量的运算二、指针变量的运算 指针运算符指针运算符(“&”和和“*”)“&”(地址运算符地址运算符):取变量的存储地址。:取变量的存储地址。“*”(引用运算符引用运算符):是取指针所指向变量的内:是取指针所指向变量的内容容。例如:&a 是求变量a的地址。ptr指向了i变量,*ptr表示i的值,即3 我们还可以用这种方法实现对变量的改变:我们还可以用这种方法实现对变量的改变:*ptr=15;等价于等价于 i=15;由由此此可可见见:通过指针运算符“*”可以引用一个变量。如:当ptr已经指向变量i后,*ptr就等同于i。进一步理解进一步理解“&”和和“*”:“&”运算和运算和“*”运算是一对互逆运运算是一对互逆运算。算。&*ptr&i ptr *&i *ptr i等价于 指针的赋值运算(指针的赋值运算(=)指针的赋值运算指针的赋值运算:就是把地址赋值给指针变量。:就是把地址赋值给指针变量。指针的赋值运算可以是以下三种方式指针的赋值运算可以是以下三种方式:使用取地址运算符,把地址值赋值给指针变量。使用取地址运算符,把地址值赋值给指针变量。如:int i,*pi;pi=&i;把指针变量的值赋给另一个指针变量。把指针变量的值赋给另一个指针变量。如:int i,*pa,*pb;pa=&i;pb=pa;给指针变量赋值为符号常量给指针变量赋值为符号常量NULL。说说明明:NULL是是一一个个空空指指针针,表表示示该该指指针针变变量量的的值值没没有有意意义义。作作用用是是为为了了避避免免对对没没有有被被初初始始化化的的指指针针变变量的非法引用。量的非法引用。NULL 的定义在的定义在“stdio.h”中。中。如:int*pi;pi=NULL;说明:说明:在定义指针变量时,可以立即将一个地址值在定义指针变量时,可以立即将一个地址值 赋给指针变量,这就是指针变量的初始化。赋给指针变量,这就是指针变量的初始化。指针变量的初始化也是指针的赋值运算。指针变量的初始化也是指针的赋值运算。如:如:float flt,*f_ptr=&flt;注意:这不是给注意:这不是给*f_ptr赋值赋值。指针变量间的赋值和引用应保证基类型相同。指针变量间的赋值和引用应保证基类型相同。若有定义:若有定义:int*p,i;float*q,x;则:则:q=&i;p=&x;移动指针的运算移动指针的运算 指针的加减运算(指针的加减运算(+、)、)指针的自加自减运算(指针的自加自减运算(+,-,+=,-=)1 1指针的指针的+、运算、运算 指针整数指针指针+、说明说明:指针与整型值加减的结果是指针指针与整型值加减的结果是指针,表示使该指针,表示使该指针指向该指针下移或上移存储单元个数指向该指针下移或上移存储单元个数(整型值整型值)之后之后的内存地址。存储单元的大小就是该指针的数据类的内存地址。存储单元的大小就是该指针的数据类型所需的内存大小。型所需的内存大小。例如:ptr+n(指针ptr,n为整数)这个指针值代表的内存单元的地址是:ptr+n*d(其中d是指针所指向变量的数据类型所占内存字节数),即指针移动了n个元素。指针与指针的加运算毫无意义,所以指针与指针的加运算毫无意义,所以指针与指针指针与指针 没有加运算没有加运算。指针与指针的减运算要求相减的两个指针属于同指针与指针的减运算要求相减的两个指针属于同 一类型,其结果是整数,表示两个指针之间的数一类型,其结果是整数,表示两个指针之间的数 据的个数。其结果值的计算公式是:据的个数。其结果值的计算公式是:ptr1-ptr2=(ptr1的值-ptr2的值)/指针的数据类型所占的字节数 例如:int*ptr1,*ptr2,*ptr3,x;int ary5=2,4,8,16,32;ptr1=&ary0;ptr2=&ary3;ptr3=ary;x=ptr2-ptr1;x 的值是32 2指针的指针的+、-、+=+=、-=-=运算运算 +、+=+=:是移动指针到下一个或下几个存储单元。是移动指针到下一个或下几个存储单元。-、-=-=:是移动指针到上一个或上几个存储单元。是移动指针到上一个或上几个存储单元。例如:例如:int*ptr,ary5=2,4,6,8,10;ptr=ary;ptr+=3;ptr-;想一想:想一想:*ptr+和(和(*ptr)+有什么有什么 的区别的区别?关系运算关系运算 基类型相同的两个指针进行比较运算,其意义是两个指针的位置比较,结果是逻辑值。指针运算的程序举例:指针运算的程序举例:把把a,b按大小顺序输出。按大小顺序输出。main()int*p1,*p2,*p,a,b;a=45;b=76;p1=&a;p2=&b;if(*p1*p2)p=p1;p1=p2;p2=p;printf(a=%d,b=%d,max=%d,min=%d,a,b,*p1,*p2);输出结果:a=45,b=76,max=76,min=45三、指针变量作为函数参数三、指针变量作为函数参数 指针可以用作函数参数,这在调用函数希望指针可以用作函数参数,这在调用函数希望改变参数的值时非常有用。改变参数的值时非常有用。例如:用指针变量编写实现两个数的交换的函数例如:用指针变量编写实现两个数的交换的函数void swap(int*p1,int*p2);main()int x1=100,x2=200;printf(x1=%d,x2=%dn,x1,x2);swap(&x1,&x2);printf(x1=%d,x2=%dn,x1,x2);void swap(int*p1,int*p2)int temp;temp=*p1;*p1=*p2;*p2=temp;图示交换过程中存储单元内容的变化:图示交换过程中存储单元内容的变化:123456想一想:想一想:如果函数的参数不用指针而用整数,如果函数的参数不用指针而用整数,能否实现值的交换?为什么?能否实现值的交换?为什么?通过函数调用得到通过函数调用得到n个要改变的值的方法:个要改变的值的方法:在主调函数中设在主调函数中设n个变量,用个变量,用n个指针变量指向它们;个指针变量指向它们;将指针变量作实参,将这将指针变量作实参,将这n个变量的地址传给所调用个变量的地址传给所调用 的函数的形参;的函数的形参;通过形参指针变量,改变该通过形参指针变量,改变该n个变量的值;个变量的值;主调函数中就可以使用这些改变了值的变量。主调函数中就可以使用这些改变了值的变量。注意:注意:不能企图通过改变指针形参的值而使指不能企图通过改变指针形参的值而使指 针实参的值改变。针实参的值改变。如:上例如:上例swap函数中不能写成:函数中不能写成:temp=p1;p1=p2;p2=temp;10.3 10.3 数组的指针和指向数组的指针变量数组的指针和指向数组的指针变量 一、数组的指针和指向数组的指针变量的概念一、数组的指针和指向数组的指针变量的概念 数组的指针数组的指针:是数组的起始地址。:是数组的起始地址。数组元素的指针数组元素的指针:是数组元素的地址。:是数组元素的地址。当指针变量指向数组或数组元素时,它就当指针变量指向数组或数组元素时,它就是是指向数组的指针变量指向数组的指针变量。C规定规定:数组名代表数组的首地址(起始地址),数组名代表数组的首地址(起始地址),也就是第一个元素的地址。也就是第一个元素的地址。当指针变量当指针变量p指向数组时,指向数组时,p+1指向数组指向数组 的下一个元素。假设一个整型元素占两的下一个元素。假设一个整型元素占两 个字节,个字节,p+1是使是使p的地址加的地址加2个字节。个字节。如:如:int a10,*p;则:则:p=a;与与 p=&a0;等价等价称指针变量称指针变量p指向数组元素指向数组元素a0 p+i、a+i、&ai 都是都是ai的地址。的地址。二、数组元素的引用二、数组元素的引用 1.用下标法引用数组元素用下标法引用数组元素如:如:a3=45;b25=200;2.用指针法引用数组元素用指针法引用数组元素 假如:假如:int a10,*p,i;p=a;则:则:*(p+i)、*(a+i)则代表元素则代表元素ai *(p+i)也可以写成也可以写成pi *(p+i)、*(a+i)、ai、pi 等价,等价,都代表数组都代表数组a的第的第i+1个元素。个元素。程序举例:输出程序举例:输出10个元素数组中的全部元素。个元素数组中的全部元素。方法二:通过数组名计算数组元素地址,找出元素的方法二:通过数组名计算数组元素地址,找出元素的 值。值。main()int a10=54,65,8,2,3,56,8,21,57,98,i;for(printf(n),i=0;i10;i+)printf(%4d,*(a+i);方法一:下标法。方法一:下标法。main()int a10=54,65,8,2,3,56,8,21,57,98,i;for(printf(n),i=0;i10;i+)printf(%4d,ai);方法三:用指针变量指向数组元素方法三:用指针变量指向数组元素 main()int a10=54,65,8,2,3,56,8,21,57,98,*p,i;p=a;for(printf(n),i=0;i10;i+)printf(%4d,*p+);以上三种方法,利用指针变量效率最高。以上三种方法,利用指针变量效率最高。说明:说明:指针变量与数组名的区别:指针变量与数组名的区别:指针变量是地址变量,指针变量是地址变量,数组名是地址常量数组名是地址常量。即。即指针变量的内容可以在程序运行过程中被改变;而指针变量的内容可以在程序运行过程中被改变;而数组名一旦被定义,它的值就不能被改变了。数组名一旦被定义,它的值就不能被改变了。例如:int i,*p,a6;则:p=&i;a=&i;a+;a+=i;不能给常量赋值利用指针变量编程时特别要注意指针变量利用指针变量编程时特别要注意指针变量 的当前值。的当前值。例如:通过指针变量输入输出a数组元素。main()int*p,i,a10;p=a;for(i=0;i10;i+)scanf(%d,p+);for(printf(“n”),i=0;i10;i+)printf(“%6d”,*p+);应插入语句 p=a;注意:注意:*p+、*(p+)、(*p)+、*(+p)的含义的含义 三、数组名作函数的参数三、数组名作函数的参数 例如:f(int arr,int n)main()int array10;f(array,10);现在解释:实际上,能够接受并存放地址值的只能是指针变量。因此,C编译系统都是将形参数组名作为指针变量来处理的。上例中f(int arr,int n)等价于等价于 f(int*arr,int n)。使用形参数组的概念只是为了与实参数组对应,直观,便于理解而已。例:从例:从10个数中找出其中最大值和最小值。个数中找出其中最大值和最小值。void max_min(int a,int n,int*max,int*min);main()int i,a=2,4,1,6,7,32,45,75,45,90,max,min;for(printf(The original array=),i=0;i10;i+)printf(%5d,ai);max_min(a,10,&max,&min);printf(max=%d min=%d,max,min);void max_min(int a,int n,int*max,int*min)int i;*max=*min=a0;for(i=0;in;i+)if(*maxai)*min=ai;上例中如果形参数组用指针变量,则程序如下:上例中如果形参数组用指针变量,则程序如下:void max_min(int*x,int n,int*max,int*min);main()int i,a10=2,4,1,6,7,32,45,75,45,90,max,min;for(printf(The original array=),i=0;i10;i+)printf(%5d,ai);max_min(a,10,&max,&min);printf(=%d min=%d,max,min);void max_min(int*x,int n,int*max,int*min)int i;*max=*min=*x;for(i=1;in;i+,x+)if(*max*x)*min=*x;数组名做函数参数小结数组名做函数参数小结:如果有一个实参数组,想在函数中改变此数组如果有一个实参数组,想在函数中改变此数组的元素的值,实参与形参都可用数组名或指针变量的元素的值,实参与形参都可用数组名或指针变量其对应关系有以下其对应关系有以下4种情况:种情况:实参与形参都用数组名;实参与形参都用数组名;实参用数组名,形参用指针变量;实参用数组名,形参用指针变量;实参、形参都用指针变量;实参、形参都用指针变量;实参为指针变量,形参用数组名。实参为指针变量,形参用数组名。注意:注意:用指针变量作实参时一定要有确定的值。用指针变量作实参时一定要有确定的值。例:实参、形参都用指针变量的形式例:实参、形参都用指针变量的形式main()int a10,*p;p=a;f(p,10);f(int*x,int n)例:实参为指针变量,形参用数组名。例:实参为指针变量,形参用数组名。main()int a10,*p;p=a;f(p,10);f(int x,int n)四、二维数组的指针四、二维数组的指针 1二维数组的指针概念二维数组的指针概念 在在C语言中,一个二维数组可以看成是一语言中,一个二维数组可以看成是一个一维数组,其中每个元素又是一个包含若干个一维数组,其中每个元素又是一个包含若干元素的一维数组。元素的一维数组。假如有定义:假如有定义:int a23;则则C语语言言编编译译程程序序认认为为a数数组组是是由由a0,a1两两个个元元素素组组成成的的一一维维数数组组,a0和和a1分分别别是是包包含含三三个个元元素素的的一一维维数数组组名名,分分别别代代表表a数数组组元元素素的的起起始始地地址址(即即a0是是第第0行行元元素素的的首首地地址址,a1是是第第1行行元元素素的的首首地地址址)。因因此此,a和和a0是是两两个个基基类型不同的指针常量类型不同的指针常量。2通过指针引用二维数组元素通过指针引用二维数组元素假如有定义:假如有定义:int a35,i,j;(其中其中0i 3,0j 5)则:则:ai和和*(a+i)(无条件等价无条件等价)都是第)都是第i行第行第0列列 元素的地址,那么元素的地址,那么ai+j、*(a+i)+j、&a00+5*i+j都是第都是第i行第行第j列元素的地址。列元素的地址。数组数组a中任意元素中任意元素aij的引用可以表示成如的引用可以表示成如 下几种形式:下几种形式:aij、*(ai+j)、*(*(a+i)+j)、(*(a+i)j、*(&a00+5*i+j)3通过一个行指针变量引用二维数组的元素通过一个行指针变量引用二维数组的元素 定义一个由定义一个由m个元素组成的一维数组的指个元素组成的一维数组的指针变量的一般形式:针变量的一般形式:类型标识符类型标识符(*(*指针变量名指针变量名)m;m;例如:假若有语句例如:假若有语句 int a23,(*p)3;p=a;注意:注意:*p两侧的圆括号不可缺少。两侧的圆括号不可缺少。则:则:p是一个指向由是一个指向由3个整型元素组成的一个整型元素组成的一 维数维数 组的指针变量。组的指针变量。p指向指向a数组,数组,p+1指向数组指向数组a的下一行首地的下一行首地 址,址,a和和p的基类型相同,则的基类型相同,则a数组中任意元数组中任意元 素素aij还可以如下表示:还可以如下表示:*(pi+j)、*(*(p+i)+j)、(*(p+i)j、pij 例:使用行指针变量访问数组元素。例:使用行指针变量访问数组元素。main()float fa510,(*pf)10=fa;int i,j;for(i=0;i5;i+)for(j=0;j10;j+)*(*(pf+i)+j)=i*j;for(i=0;i5;i+)for(puts(),j=0;jy)z=x;else z=y;return z;10.7 10.7 指针数组和指向指针的指针指针数组和指向指针的指针 一、指针数组一、指针数组 指针数组:指针数组:就是数组中每个元素是基类型相同就是数组中每个元素是基类型相同 指针变量。指针变量。定义指针数组的一般形式定义指针数组的一般形式:类型标识符类型标识符*指针变量名指针变量名 常量表达式常量表达式;例如:例如:int*p2;含意:含意:p是一个一维指针数组,每个元素都是是一个一维指针数组,每个元素都是 一个指向整型变量的指针变量。可以将一个指向整型变量的指针变量。可以将 整型变量的地址赋值给元素整型变量的地址赋值给元素p0或或p1。注意:注意:区别区别 int*p2 、int (*p)2 的含的含意。意。二、指针数组的应用二、指针数组的应用 1.利用指针数组处理多个串利用指针数组处理多个串 方法方法:先用指针数组指向字符数组:先用指针数组指向字符数组,再处理。再处理。main()char name80=aaa,bbb,ccc,ddd,eee;char*pname10,i;for(i=0;i5;i+)pnamei=namei;for(i=0;i5;i+)puts(pnamei);main()/*与用行指针解决上述问题比较与用行指针解决上述问题比较*/char name80=aaa,bbb,ccc,ddd,eee;char(*pname)80=name,i;for(i=0;i5;i+)puts(pnamei);方法方法:用指针数组指向字符串常量。:用指针数组指向字符串常量。main()char *pname10=aaa,bbb,ccc,ddd,eee;int i;for(i=0;i5;i+)puts(pnamei);2.用指针数组指向动态内存用指针数组指向动态内存 void指针类型介绍:指针类型介绍:新标准增加了新标准增加了void指针类型,它用于定义一个指指针类型,它用于定义一个指针变量,但不指定它是指向哪种类型数据。在将它针变量,但不指定它是指向哪种类型数据。在将它的值赋给另一个指针变量时要进行强制类型转换使的值赋给另一个指针变量时要进行强制类型转换使之适合于被赋值的变量的类型。之适合于被赋值的变量的类型。例如:例如:char *p1;int a=2;void *p2;p2=&a;p1=(char*)p2;强制类型转换强制类型转换void指针变量定义指针变量定义 同样,可用同样,可用 p2=(void*)p1;将将p1的值转换成的值转换成void 指针类型。指针类型。可以将一个函数定义为可以将一个函数定义为void 指针类型。表示指针类型。表示该函数返回的是一个地址,它指向空类型,如需该函数返回的是一个地址,它指向空类型,如需要引用此地址,也需要根据情况进行类型转换。要引用此地址,也需要根据情况进行类型转换。如如,库函数:库函数:void*malloc(unsigned size);功能:分配功能:分配size字节的存储区。字节的存储区。函数调用例函数调用例:char*p;p=(char*)malloc(60);分配分配60字节的存储区,并返回该字节的存储区,并返回该内存区的地址,并赋值给内存区的地址,并赋值给p。void sort(char*ps,int n);#define N 5main()char*ps100,i;for(i=0;iN;i+)psi=(char*)malloc(60);for(i=0;iN;i+)gets(psi);sort(ps,N);for(i=0;iN;i+)puts(psi);void sort(char*ps,int n)int i,k;char*p,s100;for(i=0;in-1;i+)for(k=i+1;kn;k+)if(strcmp(psi,psk)0)p=psi;psi=psk;psk=p;例:用指针数组指向动态内存,进行字符串的排序。例:用指针数组指向动态内存,进行字符串的排序。3.指针数组作指针数组作main函数的形参函数的形参 main函数是由系统调用的,可以有参数。函数是由系统调用的,可以有参数。可执行文件名可执行文件名 参数参数1 1 参数参数2 2 参数参数n n 实参是和命令一起给出的,也就是在实参是和命令一起给出的,也就是在DOS提提示符下,输入本程序的可执行文件名和需要传给示符下,输入本程序的可执行文件名和需要传给main函数的参数,命令行的一般形式为:函数的参数,命令行的一般形式为:main函数实参函数实参:带参数的带参数的main函数的原型是:函数的原型是:main(int argc,char*argv);命令行参数命令行参数(包包括可执行文件名)括可执行文件名)的数目的数目n+1指针数组,各元素分别指向命令指针数组,各元素分别指向命令行中的各参数(包括可执行文件行中的各参数(包括可执行文件名),即字符串的首址名),即字符串的首址例:若以下面程序编译后生成可执行程序例:若以下面程序编译后生成可执行程序 file.exe,在在DOS提示符下按下述形式执行程序:提示符下按下述形式执行程序:file China Bejing Shenyang 写出程序运行结果。写出程序运行结果。#include main(int argc,char*argv)while(argc0)printf(“%sn”,argvargc);运行结果:运行结果:ShenyangBejingChina三、指向指针的指针变量三、指向指针的指针变量 指指向向指指针针的的指指针针变变量量(也也称称多多级级指指针针)只只能存放指针变量的地址能存放指针变量的地址。定义形式:定义形式:类型标识符类型标识符 *指针变量名指针变量名;例如:例如:int*q,*p,i=5;p=&i;q=&p;5i20002000p4000q4000注意:注意:要使用一个多级指针要使用一个多级指针指向目标值,必须连续使用指向目标值,必须连续使用指针运算符指针运算符“*”。例如:上例中例如:上例中*q就是就是i的值。的值。含意:使指针变量含意:使指针变量p指向指向i,指针变量指针变量q指向指向p。10.8.8 指针的数据类型小结指针的数据类型小结 定定 义义含含 义义 int *p;p为指向整型数据的指针变量为指向整型数据的指针变量 int *pn;定义指针数组定义指针数组p,它有它有n n个指向整个指向整型数据的指针元素型数据的指针元素 int(*p)n;p为指向含为指向含n n个元素的一维数组的个元素的一维数组的指针变量指针变量 int *p();p为带回一个指针的函数,该指针为带回一个指针的函数,该指针指向整型数据指向整型数据 int (*p)();p为指向函数的指针,该函数返回为指向函数的指针,该函数返回一个整型值一个整型值 int *p;p是一个指针变量,它指向一个指是一个指针变量,它指向一个指向整型数据的指针变量向整型数据的指针变量本章程序举例:本章程序举例:习题习题10.1:输入:输入3个整数,按由小到大的顺序输出。个整数,按由小到大的顺序输出。void swap(int*p,int*q);main()int a=9,b=7,c=10,*p1,*p2,*p3;p1=&a;p2=&b;p3=&c;if(*p1*p2)swap(p1,p2);if(*p1*p3)swap(p1,p3);if(*p2*p3)swap(p2,p3);printf(n%6d%6d%6d,*p1,*p2,*p3);void swap(int*p,int*q)int x;x=*p;*p=*q;*q=x;习题习题10.2:输入:输入3个字符串,按由小到大的顺序输出。个字符串,按由小到大的顺序输出。void swap(char*ps1,char*ps2);main()char s1=abc,s2=rst,s3=xyz;if(strcmp(s1,s2)0)swap(s1,s2);if(strcmp(s1,s3)0)swap(s1,s3);if(strcmp(s2,s3)0)swap(s2,s3);printf(n%10s%10s%10s,s1,s2,s3);void swap(char*ps1,char*ps2)char ps100;strcpy(ps,ps1);strcpy(ps1,ps2);strcpy(ps2,ps);习题习题10.9:写一函数,将一个:写一函数,将一个33的矩阵转置。的矩阵转置。main()int a33=1,2,3,4,5,6,7,8,9,i,j;for(i=0;i3;i+)for(puts(),j=0;j3;j+)printf(%6d,aij);move(a);for(i=0;i3;i+)for(puts(),j=0;j3;j+)printf(%6d,aij);move(int(*p)3)int i,j,t;for(i=0;i3;i+)for(j=0;j=A&*p=a&*p=0&*p=9)num+;else if(*p=)space+;p+;printf(n upc=%d lowc=%d num=%d space=%d,upc,lowc,num,space);习题习题10.11:对:对10个等长的字符串排序并输出。个等长的字符串排序并输出。void sort(char(*p)60);main()char s1060,i;for(i=0;i10;i+)gets(s+i);sort(s);for(i=0;i10;i+)puts(s+i);void sort(char(*p)60)int i,j;char s60;for(i=0;i9;i+)for(j=i+1;j10;j+)if(strcmp(pi,pj)0)strcpy(s,pi);strcpy(pi,pj);strcpy(pj,s);10.12:用指针数组处理上一个题目,字符串不:用指针数组处理上一个题目,字符串不 等长。等长。void sort(char*p,int n);main()char *s10=AAA,DDD,878787,*ps10,i;for(i=0;i10;i+)psi=si;sort(ps,4);for(i=0;i4;i+)puts(psi);void sort(char*ps,int n)int i,j;char *s;for(i=0;in-1;i+)for(j=i+1;jn;j+)if(strcmp(psi,psj)0)s=psi,psi=psj,psj=s;习题习题10.14:将:将n个数按输入时顺序的逆序排列,用个数按输入时顺序的逆序排列,用 函数实现。函数实现。void inverse(int*a,int n);main()int i,a10=2,4,1,6,7,32,45,75,450,89;for(puts(),i=0;i10;i+)printf(%5d,ai);inverse(a,10);for(puts(),i=0;i10;i+)printf(%5d,ai);void inverse(int*x,int n)int*i=x,*j=x+n-1,t;for(;i=0&*ps0)ai+=n;n=0;if(n0)ai+=n;for(n=0;ni;n+)printf(%6d,an);习题习题10.18:根据输入的月份输出月的英文名。:根据输入的月份输出月的英文名。main()char*month=January,February,March,April,May,June,July,August,Septermber,October,Noverber,Decermber;int mon;scanf(%d,&mon);if(mon12)printf(month error!);else puts(monthmon-1);10.4:有:有N个数,使前面各数顺序向后移个数,使前面各数顺序向后移M个位置。个位置。main()int num20,m,n,i;printf(m=n=);scanf(%d%d,&m,&n);for(i=0;in;i+)scanf(%d,num+i);move(num,n,m);for(i=0;in;i+)printf(%6d,*(num+i);move(int*pnum,int n,int m)int t,i,j;for(i=0;i0;j-)*(pnum+j)=*(pnum+j-1);*pnum=t;习题习题10.7:有一字符串包含:有一字符串包含N个字符,写一个函数,个字符,写一个函数,将字符串中从第将字符串中从第M个字符开始的全部字个字符开始的全部字 符复制成为另一个字符串。符复制成为另一个字符串。main()char sn100=fasjfkjsdfsdfjsdjkfdfjssdf,sm100;int n=strlen(sn),m=n/2;scopy(sn,sm,m);printf(n sn=%s n m=%d n sm=%s,sn,m,sm);scopy(char*psn,char*psm,int m)while(*(psn+m)*psm+=*(m+psn+);*psm=0;习题习题10.7:有一字符串包含:有一字符串包含N个字符,写一个函数,个字符,写一个函数,将字符串中从第将字符串中从第M个字符开始的全部字个字符开始的全部字 符复制成为另一个字符串。符复制成为另一个字符串。main()char sn100=fasjfkjsdfsdfjsdjkfdfjssdf,sm100;int n=strlen(sn),m=n/2;scopy(sn,sm,m);printf(n sn=%s n m=%d n sm=%s,sn,m,sm);scopy(char*psn,char*psm,int m)while(*(psn+m)*psm+=*(m+psn+);*psm=0;习题习题10.7:有一字符串包含:有一字符串包含N个字符,写一个函数,个字符,写一个函数,将字符串中从第将字符串中从第M个字符开始的全部字个字符开始的全部字 符复制成为另一个字符串。符复制成为另一个字符串。main()char sn100=fasjfkjsdfsdfjsdjkfdfjssdf,sm100;int n=strlen(sn),m=n/2;scopy(sn,sm,m);printf(n sn=%s n m=%d n sm=%s,sn,m,sm);scopy(char*psn,char*psm,int m)while(*(psn+m)*psm+=*(m+psn+);*psm=0;

    注意事项

    本文(第10章 指针,c语言.ppt)为本站会员(hyn****60)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开