c语言指针习题及答案.doc
《c语言指针习题及答案.doc》由会员分享,可在线阅读,更多相关《c语言指针习题及答案.doc(15页珍藏版)》请在咨信网上搜索。
. . 指针主要容的习题及答案 一.选择题 1.变量的指针,其含义是指该变量的B。 A〕值 B〕地址 C〕名 D〕一个标志 2.已有定义int k=2;int *ptr1,*ptr2;且ptr1和ptr2均已指向变量k,下面不能正确执行的赋值语句是B。 A〕k=*ptr1+*ptr2 B〕ptr2=k C〕ptr1=ptr2 D〕k=*ptr1*(*ptr2) 3.假设有说明:int *p,m=5,n;以下程序段正确的选项是D。 A〕p=&n ; B〕p = &n ; scanf(“%d〞,&p); scanf(“%d〞,*p); C〕scanf(“%d〞,&n); D〕p = &n ; *p=n ; *p = m ; 4.已有变量定义和函数调用语句:int a=25;print_value(&a);下面函数的输出结果是D。 void print_value(int *x) { printf(“%d\n〞,++*x); } A〕23 B〕24 C〕25 D〕26 5.假设有说明:int *p1, *p2,m=5,n;以下均是正确赋值语句的选项是C。 A〕p1=&m; p2=&p1 ; B〕p1=&m; p2=&n; *p1=*p2 ; C〕p1=&m; p2=p1 ; D〕p1=&m; *p1=*p2 ; 6.假设有语句:int *p,a=4;和p=&a;下面均代表地址的一组选项是D。 A〕a,p,*&a B〕&*a,&a,*p C〕*&p,*p,&a D〕&a,&*p,p 7.下面判断正确的选项是C。 A〕char *a=〞china〞; 等价于 char *a; *a=〞china〞 ; B〕char str[10]={“china〞}; 等价于 char str[10]; str[ ]={“china〞;} C〕char *s=〞china〞; 等价于 char *s; s=〞china〞 ; D〕char c[4]=〞abc〞,d[4]=〞abc〞; 等价于 char c[4]=d[4]=〞abc〞 ; 8.下面程序段中,for循环的执行次数是C。 char *s=〞\ta\018bc〞 ; for ( ; *s!=’\0’ ; s++) printf(“*〞) ; A〕9 B〕7 C〕6 D〕5 9.下面能正确进展字符串赋值操作的是C。 A〕char s[5]={“ABCDE〞}; B〕char s[5]={‘A’,’B’,’C’,’D’,’E’}; C〕char *s ; s=〞ABCDE〞 ; D〕char *s; scanf(“%s〞,s) ; 10.下面程序段的运行结果是C。 char *s=〞abcde〞 ; s+=2 ; printf(“%d〞,s); A〕cde B〕字符’c’ C〕字符’c’的地址 D〕不确定 11.设p1和p2是指向同一个字符串的指针变量,c为字符变量,那么以下不能正确执行的赋值语句是B。 A〕c=*p1+*p2 B〕p2=c C〕p1=p2 D〕c=*p1*(*p2) 12.设有程序段:char s[ ]=〞china〞; char *p ; p=s ;那么下面表达正确的选项是D。 A〕s和p完全一样 B〕数组s中的容和指针变量p中的容相等 C〕s数组长度和p所指向的字符串长度相等 D〕*p与s[0]相等 13.以下与库函数strcpy(char *p1,char *p2)功能不相等的程序段是D。 A〕strcpy1(char *p1,char *p2) { while ((*p1++=*p2++)!=’\0’) ; } B〕strcpy2(char *p1,char *p2) { while ((*p1=*p2)!=’\0’) { p1++; p2++ } } C〕strcpy3(char *p1,char *p2) { while (*p1++=*p2++) ; } D〕strcpy4(char *p1,char *p2) { while (*p2) *p1++=*p2++ ; } 14.下面程序段的运行结果是C。 char a[ ]=〞language〞 , *p ; p=a ; while (*p!=’u’) { printf(“%c〞,*p-32); p++ ; } A〕LANGUAGE B〕language C〕LANG D〕langUAGE 16.以下与库函数strcmp(char *s,char *t)功能相等的程序段是C。 A〕strcmp1(char *s,char *t) { for ( ; *s++=*t++; ) if (*s==’\0’) return 0 ; return (*s-*t) ; } B〕strcmp2(char *s,char *t) { for ( ; *s++=*t++; ) if (!*s) return 0 ; return (*s-*t) ; } C〕strcmp3(char *s,char *t) { for ( ; *t==*s; ) { if (!*t) return 0 ; t++ ; s++ ; } return (*s-*t) ; } D〕strcmp4(char *s,char *t) { for ( ; *s==*t; s++, t++ ) if (!*s) return 0 ; return (*t-*s) ; } 17.以下说明不正确的选项是D。 A〕char a[10]=〞china〞 ; B〕char a[10],*p=a; p=〞china〞; C〕char *a; a=〞china〞 ; D〕char a[10],*p; p=a=〞china〞; 18.设有说明语句:char a[]=〞It is mine〞;char *p=〞It is mine〞;那么以下不正确的表达是D。 A〕a+1表示的是字符t的地址 B〕p指向另外的字符串时,字符串的长度不受限制 C〕p变量中存放的地址值可以改变 D〕a中只能存放10个字符 19.假设已定义char s[10];那么在下面表达式中不表示s[1]的地址是B。 A〕s+1 B〕s++ C〕&s[0]+1 D〕&s[1] 20.假设有定义:int a[5],*p=a;那么对a数组元素的正确引用是D。 A〕*&a[5] B〕a+2 C〕*(p+5) D〕*(a+2) 21.假设有定义:int a[5],*p=a;那么对a数组元素地址的正确引用是D。 A〕p+5 B〕*a+1 C〕&a+1 D〕&a[0] 22.假设有定义:int a[2][3];那么对a数组的第i行第j列元素值的正确引用是 A。 A〕*(*(a+i)+j) B〕(a+i)[j] C〕*(a+i+j) D〕*(a+i)+j 23.假设有定义:int a[2][3];那么对a数组的第i行第j列元素地址的正确引用是D。 A〕*(a[i]+j) B〕(a+i) C〕*(a+j) D〕a[i]+j 24.假设有程序段:int a[2][3],(*p)[3]; p=a;那么对a数组元素地址的正确引用是。 A〕*(p+2) B〕p[2] C〕p[1]+1 D〕(p+1)+2 25.假设有程序段:int a[2][3],(*p)[3]; p=a;那么对a数组元素的正确引用是C。 A〕(p+1)[0] B〕*(*(p+2)+1) C〕*(p[1]+1) D〕p[1]+2 26.假设有定义:int a[5];那么a数组中首元素的地址可以表示为C。 A〕&a B〕a+1 C〕a D〕&a[1] 27.假设有定义:int (*p)[4];那么标识符pC。 A〕是一个指向整型变量的指针 B〕是一个指针数组名 C〕是一个指针,它指向一个含有四个整型元素的一维数组 D〕定义不合法 28.以下与int *q[5];等价的定义语句是C。 A〕int q[5] B〕int *q C〕int *(q[5]) D〕int (*q)[5] 29.以下正确的说明语句是B。 A〕int *b[]={1,3,5,7,9} ; B〕int a[5],*num[5]={&a[0],&a[1],&a[2],&a[3],&a[4]}; C〕int a[]={1,3,5,7,9}; int *num[5]={a[0],a[1],a[2],a[3],a[4]}; D〕int a[3][4],(*num)[4]; num[1]=&a[1][3]; 30.假设有定义:int b[4][6],*p,*q[4];且0≤i<4,那么不正确的赋值语句是D。 A〕q[i]=b[i]; B〕p=b; C〕p=b[i]; D〕q[i]=&b[0][0] 32.假设要对a进展自减运算,那么a应有下面说明D。 A〕int p[3]; B〕int k; C〕char *a[3] D〕int b[10]; int *a=p; int *a=&k; int *a=b+1; 33.以下选项中,对指针变量p的正确操作是B。 A〕int a[3], *p; B〕int a[5], *p; C〕int a[5]; D〕int a[5] p=&a; p=a; int *p=a=100; int *p1,*p2=a; *p1=*p2; 34.假设有定义:int x[10]={0,1,2,3,4,5,6,7,8,9},*p1;那么数值不为3的表达式是C。 A〕x[3] B〕p1=x+3,*p1++ C〕p1=x+2,*(p1++) D〕p1=x+2,*++p1 35.下面程序段的输出是C。 int a[ ]={2,4,6,8,10,12,14,16,18,20,22,24},*q[4],k; for (k=01; k<4; k++) q[k]=&a[k*3]; printf(“%d\n〞,q[3][0]); A〕8 B〕16 C〕20 D〕输出不合法 36.假设要对a进展自增运算,那么a应具有下面说明D。 A〕int a[3][2]; B〕char *a[ ]={“12〞,〞ab〞}; C〕char (*a) [3] D〕int b[10], *a=b; 37.假设有定义int a[4][6];那么能正确表示a数组中任一元素a[i][j]〔i,j均在有效围〕地址的表达式A。 A〕&a[0][0]+6*i+j B〕&a[0][0]+4*j+i C〕&a[0][0]+4*i+j D〕&a[0][0]+6*j+I 38.下面程序的运行结果是B。 main ( ) { int x[5]={2,4,6,8,10}, *p, **pp ; p=x , pp = &p ; printf(“%d〞,*(p++)); printf(“%3d〞,**pp); } A〕4 4 B〕2 4 C〕2 2 D〕4 6 39.假设有定义int x[4][3]={1,2,3,4,5,6,7,8,9,10,11,12}; int (*p)[3]=x ; 那么能够正确表示数组元素x[1][2]的表达式是D。 A〕*((*p+1)[2]) B〕(*p+1)+2 C〕*(*(p+5)) D〕*(*(p+1)+2) 40.假设有说明:char *language[]={“FORTRAN〞,〞BASIC〞,〞PASCAL〞,〞JAVA〞,〞C〞};那么language[2]的值是B。 A〕一个字符 B〕一个地址 C〕一个字符串 D〕一个不定值 41.设有定义:char *cc[2]={“1234〞,〞5678〞};那么正确的表达是A。 A〕cc数组的两个元素中各自存放了字符串〞1234〞和〞5678〞的首地址 B〕cc数组的两个元素分别存放的是含有4个字符的一维字符数组的首地址 C〕cc是指针变量,它指向含有两个数组元素的字符型一维数组 D〕cc元素的值分别维〞1234〞和〞5678〞 42.已有定义int (*p)( );指针p可以B。 A〕代表函数的返回值 B〕指向函数的入口地址 C〕表示函数的类型 D〕表示函数返回值的类型 43.已有函数max(a,b),为了让函数指针变量p指向函数max,正确的赋值方法是A。 A〕p=max; B〕p=max(a,b); C〕*p=max; D〕*p=max(a,b); 44.假设有函数max(a,b),并且已使函数指针变量p指向函数max,当调用该函数时,正确的调用方法是C或 p(a,b)。 A〕(*p)max(a,b) B〕*pmax(a,b); C〕(*p)(a,b); D )*p(a,b); 45.以下正确的表达是 C。 A〕C语言允许main函数带形参,且形参个数和形参名均可由用户指定 B〕C语言允许main函数带形参,形参名只能是argc和argv C〕当main函数带有形参时,传给形参的值只能从命令行中得到 D〕假设有说明: int main(int argc,char **argv),那么argc的值必须大于1 三.程序阅读题 1.写出下面程序的运行结果。 5 func(char *s,char a,int n) { int j; *s=a; j=n ; while (*s<s[j]) j-- ; return j; } main ( ) { char c[6] ; int i ; for (i=1; i<=5 ; i++) *(c+1)=’A’+i+1; printf(“%d\n〞,func(c,’E’,5)); } 2.写出下面程序的运行结果。 6 fun (char *s) { char *p=s; while (*p) p++ ; return (p-s) ; } main ( ) { char *a=〞abcdef〞 ; printf(“%d\n〞,fun(a)) ; } 3.写出下面程序的运行结果。 abcdefglkjih sub(char *a,int t1,int t2) { char ch; while (t1<t2) { ch = *(a+t1); *(a+t1)=*(a+t2) ; *(a+t2)=ch ; t1++ ; t2-- ; } } main ( ) { char s[12]; int i; for (i=0; i<12 ; i++) s[i]=’A’+i+32 ; sub(s,7,11); for (i=0; i<12 ; i++) printf (“%c〞,s[i]); printf(“\n〞); } 4.当运行以下程序时,写出输入 6↙的程序运行结果。 976531 sub(char *a,char b) { while (*(a++)!=’\0’) ; while (*(a-1)<b) *(a--)=*(a-1); *(a--)=b; } main ( ) { char s[]=〞97531〞,c; c = getchar ( ) ; sub(s,c); puts(s) ; } 5.写出下面程序的运行结果。 Java dBase C Language Pascal main ( ) { char *a[]={“Pascal〞,〞C Language〞,〞dBase〞,〞Java〞}; char (**p)[ ] ; int j ; p = a + 3 ; for (j=3; j>=0; j--) printf(“%s\n〞,*(p--)) ; } 四.程序填空题 1.下面函数的功能是从输入的十个字符串中找出最长的那个串,请填(2)空使程序完整。 void fun(char str[10][81],char **sp) { int i; *sp = 【1str[0]】; for (i=1; i<10; i++) if (strlen (*sp)<strlen(str[i])) 【2*sp=str[i]】; } 2.下面函数的功能是将一个整数字符串转换为一个整数,例如:〞-1234〞转换为1234,请填(3)空使程序完整。 int chnum(char *p) { int num=0,k,len,j ; len = strlen(p) ; for ( ; 【1*p!=’\0’】; p++) { k=【2*p-‘0’】; j=(--len) ; while (【3 j--!=0】) k=k*10 ; num = num + k ; } return (num); } 3.下面函数的功能使统计子串substr在母串str中出现的次数,请填(3)空使程序完整。 int count(char *str, char *substr) { int i,j,k,num=0; for ( i=0; 【1str[i]!=’\0’】; i++) for (【2j=i】, k=0; substr[k]==str[j]; k++; j++) if (substr [【3k】]==’\0’) { num++ ; break ; } return (num) ; } 6.下面函数的功能是将两个字符串s1和s2连接起来,请填(2)空使程序完整。 void conj(char *s1,char *s2) { while (*s1) 【1s1++】; while (*s2) { *s1=【2*s2】; s1++,s2++; } *s1=’\0’ ; } 五.编程题 1.定义3个整数及整数指针,仅用指针方法按由小到大的顺序输出。 2.输入10个整数,将其中最小的数与第一个数对换,把最大的数与最后一个数对换。写三个函数:①输入10个数;②进展处理;③输出10个数。所有函数的参数均用指针。 3.编写一个求字符串的函数〔参数用指针〕,在主函数中输入字符串,并输出其长度。 4.编写一个函数〔参数用指针〕将一个3×3矩阵转置。 5.写函数原型为int strcmp(char *s1,char *s2);的函数,该函数实现两个字符串的比较〔函数功能描述参见教材P137,strcmp字符串处理函数〕。 6.利用指向行的指针变量求5×3数组各行元素之和。 教育之通病是教用脑的人不用手,不教用手的人用脑,所以一无所能。教育革命的对策是手脑联盟,结果是手与脑的力量都可以大到不可思议。 教育之通病是教用脑的人不用手,不教用手的人用脑,所以一无所能。教育革命的对策是手脑联盟,结果是手与脑的力量都可以大到不可思议。 . .word.zl.- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言 指针 习题 答案
咨信网温馨提示:
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【二***】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【二***】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【二***】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【二***】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
关于本文