2.15:指针习题

2024-02-17 09:20
文章标签 指针 习题 2.15

本文主要是介绍2.15:指针习题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一.选择题

1.变量的指针,其含义是指该变量的      B      

A)值               B)地址            C)名               D)一个标志

2.已有定义int k=2;int *ptr1,*ptr2;且ptr1和ptr2均已指向变量k,下面不能正确执行的赋值语句是  B  。(k值,)

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 ; (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 ;

A二级地址,b:n随机值 C: D: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” ;(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循环的执行次数是     B      。

char *s=”\ta\018bc”     \01等价于\1 0表示八进制前导符,\01  --\08  都是2个字节   \09就是3个字节

for (  ; *s!=’\0’ ; s++)  printf(“*”) ;

A)2                B)7                C)6                D)5

9.下面能正确进行字符串赋值操作的是    C        

A)char s[5]={“ABCDE”};  (\0)

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);

  1. cde          B)字符’c’       C)字符’c’的地址     D)98

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)(*p2)——*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]; 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个字符(11个)

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数组元素地址的正确引用是      C

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];则标识符p     C       

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]; (num野指针)

30.若有定义:int b[4][6],*p,*q[4];且0≤i<4,则不正确的赋值语句是 B    

A)q[i]=b[i];         B)p=b;     C)p=b[i];        D)q[i]=&b[0][0]

p一级,b二级

列:&arr[0][0]、arr[0]        行: &arr[0]、arr

32.若要对a进行自减运算,则a应有下面说明    D        

A)int p[3]; int *a=p;              B)int k; int *a=&k;                   C)char *a[3]                       D)int b[10]; int *a=b+1;

33.以下选项中,对指针变量p的正确操作是    B     

A)int a[3], *p; p=&a;      B)int a[5], *p; p=a;       

C)int a[5];int *p=a=100; (指针不能赋值)            

D)int a[5]; int *p1,*p2=a;  *p1=*p2;(p1野指针)

                                                        

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++)  2             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=0; k<4; k++) q[k]=&a[k*3];

printf(“%d\n”,q[3][0]);

A)22               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个字符的一维字符数组的首地址(5)

C)cc是指针变量,它指向含有两个数组元素的字符型一维数组

D)cc元素的值分别维”1234”和”5678”

  1. 请说明二维数组行偏移,列偏移。(7分)  *(*(a+i)+j)

例如:int arr[3][4]={1,2,3,4,5,6,7,8,9,10,11,12}

Int (*p)[4]=arr;(列偏移:&arr[0][0]——arr[0])

                  (行偏移:&arr[0]——arr)

假设arr首地址是 0x1020    指针p自身的地址是0x600

请回答:

arr+1 地址是:0x1024行偏移:0x1030

arr[0]+2 地址是:0x1028

*(arr+2)+3的地址是:0x1034      0x104c

p+2的地址是:0x1040

*(p+1)的地址是:0x1030

*(p+1)+1的地址是:0x1034

&p+2的地址是:0x610

这篇关于2.15:指针习题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/717346

相关文章

Java空指针异常NullPointerException的原因与解决方案

《Java空指针异常NullPointerException的原因与解决方案》在Java开发中,NullPointerException(空指针异常)是最常见的运行时异常之一,通常发生在程序尝试访问或... 目录一、空指针异常产生的原因1. 变量未初始化2. 对象引用被显式置为null3. 方法返回null

go 指针接收者和值接收者的区别小结

《go指针接收者和值接收者的区别小结》在Go语言中,值接收者和指针接收者是方法定义中的两种接收者类型,本文主要介绍了go指针接收者和值接收者的区别小结,文中通过示例代码介绍的非常详细,需要的朋友们下... 目录go 指针接收者和值接收者的区别易错点辨析go 指针接收者和值接收者的区别指针接收者和值接收者的

Java Optional避免空指针异常的实现

《JavaOptional避免空指针异常的实现》空指针异常一直是困扰开发者的常见问题之一,本文主要介绍了JavaOptional避免空指针异常的实现,帮助开发者编写更健壮、可读性更高的代码,减少因... 目录一、Optional 概述二、Optional 的创建三、Optional 的常用方法四、Optio

解决java.lang.NullPointerException问题(空指针异常)

《解决java.lang.NullPointerException问题(空指针异常)》本文详细介绍了Java中的NullPointerException异常及其常见原因,包括对象引用为null、数组元... 目录Java.lang.NullPointerException(空指针异常)NullPointer

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

【C++学习笔记 20】C++中的智能指针

智能指针的功能 在上一篇笔记提到了在栈和堆上创建变量的区别,使用new关键字创建变量时,需要搭配delete关键字销毁变量。而智能指针的作用就是调用new分配内存时,不必自己去调用delete,甚至不用调用new。 智能指针实际上就是对原始指针的包装。 unique_ptr 最简单的智能指针,是一种作用域指针,意思是当指针超出该作用域时,会自动调用delete。它名为unique的原因是这个

C语言指针入门 《C语言非常道》

C语言指针入门 《C语言非常道》 作为一个程序员,我接触 C 语言有十年了。有的朋友让我推荐 C 语言的参考书,我不敢乱推荐,尤其是国内作者写的书,往往七拼八凑,漏洞百出。 但是,李忠老师的《C语言非常道》值得一读。对了,李老师有个官网,网址是: 李忠老师官网 最棒的是,有配套的教学视频,可以试看。 试看点这里 接下来言归正传,讲解指针。以下内容很多都参考了李忠老师的《C语言非

C和指针:字符串

字符串、字符和字节 字符串基础 字符串就是一串零个或多个字符,并且以一个位模式为全0的NUL字节结尾。 字符串长度就是字符串中字符数。 size_t strlen( char const *string ); string为指针常量(const修饰string),指向的string是常量不能修改。size_t是无符号数,定义在stddef.h。 #include <stddef.h>

【C++】作用域指针、智能指针、共享指针、弱指针

十、智能指针、共享指针 从上篇文章 【C++】如何用C++创建对象,理解作用域、堆栈、内存分配-CSDN博客 中我们知道,你的对象是创建在栈上还是在堆上,最大的区别就是对象的作用域不一样。所以在C++中,一旦程序进入另外一个作用域,那其他作用域的对象就自动销毁了。这种机制有好有坏。我们可以利用这个机制,比如可以自动化我们的代码,像智能指针、作用域锁(scoped_lock)等都是利用了这种机制。

第六章习题11.输出以下图形

🌏个人博客:尹蓝锐的博客 希望文章能够给到初学的你一些启发~ 如果觉得文章对你有帮助的话,点赞 + 关注+ 收藏支持一下笔者吧~ 1、题目要求: 输出以下图形