牛客网上c语言的题目在哪》,牛客网上的一道题。。。

这篇博客探讨了二维数组指针的概念及其在C语言中的使用。通过一个例子,解释了如何通过指针访问二维数组的元素,特别讨论了表达式*(p+2)和*(x+2)在不同情况下的含义。博主指出,*(p+2)实际上指向x数组的第三行,即x[2][0],而*(x+2)并不等同于x[0][2]。博客还提到了指针加法在不同类型指针中的应用,并强调了指针类型匹配的重要性,以避免出现编译错误。
摘要由CSDN通过智能技术生成

int x[6][4],(*p)[4];p=x;   则*(p+2)指向哪里?

A.x[0][1]

B.x[0][2]

C.x[1][0]

D.x[2][0]

给的答案是D;

我在vs2010里编写想验证一下,如:

int main()

{

int x[3][2]={1,2,3,4,5,6};

int (*p)[2],b;

p = x;

b = *(p+1);

return 0;

}

总是报错,b = *(p+1)这句,

IntelliSense: 不能将 “int *” 类型的值分配到 “int” 类型的实体;

error C2440: “=”: 无法从“int [2]”转换为“int”;

大家帮我看看吧。。。

*(p+1)相当于p[1],其数据类型为int[2],int[2]赋值给int肯定会报错的。

原题里*(p+2)相当于p[2],应该等价于,x[2],题目问的是指向哪,相当于问*(p[2]),结果就是x[2][0]了

仅供参考:

//char (*(*x[3])())[5];//x是什么类型的变量?

//

//分析C语言声明,关键是搞清楚这个变量是个什么东西(函数、指针、数组),

//是函数那么剩下的就是他的参数和返回值,

//是指针那剩下部分是说明他指向什么,

//是数组剩下的部分就是说明数组的成员是什么类型。

//解析C语言声明规则:

//从左侧第一个标识符开始,按照优先级进行结合。*表示是..的指针,const表示只读的,volatile表示可变的,[]表示是数组,()表示是函数。

//

//x和[3]结合说明是一个大小为3的数组,该数组的每个元素为一类指针,该类指针指向一类函数,该类函数无参数,返回一类指针,该类指针指向一个大小为5的char型数组

#include 

#include 

char num[5];

char (*x00())[5] {

return #

}

int main() {

char (*(*x[3])())[5];//是个数组,大小为3

char (*(*x0  )())[5];//数组的元素,是个函数指针

char (*( x00 )())[5];//函数原型,参数为空,返回值为指针

char (*  x000   )[5];//返回值

x0 = x00;

x[0] = x0;

x[1] = x0;

x[2] = x0;

printf("typeid(x).name() is %s\n",typeid(x).name());

return 0;

}

//typeid(x).name() is char (* (__cdecl**)(void))[5]

引用 1 楼 mewiteor 的回复:

*(p+1)相当于p[1],其数据类型为int[2],int[2]赋值给int肯定会报错的。

原题里*(p+2)相当于p[2],应该等价于,x[2],题目问的是指向哪,相当于问*(p[2]),结果就是x[2][0]了

*(p+1)为什么会相当于p[1],int  (*p)[2]中的p是表示数组指针吧,即指向 一个   包含2个元素的   一维数组,如果是int *p[2],*p(+1)才是p[1]吧。。。。这里而x应该是一个 三行二列的二维数组的指针,如果是*(x+2)肯定是x[0][2],这里将二维数组的首地址强制赋给了一维数组的指针,本想验证一下,还是不太明白为什么会报错,能再说一下吗?谢谢~

引用 2 楼 zhao4zhong1 的回复:

仅供参考:

//char (*(*x[3])())[5];//x是什么类型的变量?

//

//分析C语言声明,关键是搞清楚这个变量是个什么东西(函数、指针、数组),

//是函数那么剩下的就是他的参数和返回值,

//是指针那剩下部分是说明他指向什么,

//是数组剩下的部分就是说明数组的成员是什么类型。

//解析C语言声明规则:

//从左侧第一个标识符开始,按照优先级进行结合。*表示是..的指针,const表示只读的,volatile表示可变的,[]表示是数组,()表示是函数。

//

//x和[3]结合说明是一个大小为3的数组,该数组的每个元素为一类指针,该类指针指向一类函数,该类函数无参数,返回一类指针,该类指针指向一个大小为5的char型数组

#include 

#include 

char num[5];

char (*x00())[5] {

return #

}

int main() {

char (*(*x[3])())[5];//是个数组,大小为3

char (*(*x0  )())[5];//数组的元素,是个函数指针

char (*( x00 )())[5];//函数原型,参数为空,返回值为指针

char (*  x000   )[5];//返回值

x0 = x00;

x[0] = x0;

x[1] = x0;

x[2] = x0;

printf("typeid(x).name() is %s\n",typeid(x).name());

return 0;

}

//typeid(x).name() is char (* (__cdecl**)(void))[5]

多谢老师的回答,复杂函数指针好像有个右左规则,这里只是涉及到二维数组的首地址赋给  指向一个包含2元素的1维数组指针,,指针加1后所指情况,老师能具体说一吗?谢谢

b = *(p+1);

类型不匹配,p指向二维数组,*(p+1)是这个x[1]这个数组的地址,而不是某个元素的地址。

20分

引用 3 楼 u012675103 的回复:

Quote: 引用 1 楼 mewiteor 的回复:

*(p+1)相当于p[1],其数据类型为int[2],int[2]赋值给int肯定会报错的。

原题里*(p+2)相当于p[2],应该等价于,x[2],题目问的是指向哪,相当于问*(p[2]),结果就是x[2][0]了

*(p+1)为什么会相当于p[1],int  (*p)[2]中的p是表示数组指针吧,即指向 一个   包含2个元素的   一维数组,如果是int *p[2],*p(+1)才是p[1]吧。。。。这里而x应该是一个 三行二列的二维数组的指针,如果是*(x+2)肯定是x[0][2],这里将二维数组的首地址强制赋给了一维数组的指针,本想验证一下,还是不太明白为什么会报错,能再说一下吗?谢谢~

*:当前地址指向的值.

[i]:当前地址指向的第i个元素的值

然而第i个元素的地址就是当前地址加上i*sizeof(TYPE)

p+i  C语言会自动转成 p+i*sizeof(TYPE)    (所以void*指针不能进行加减运算)

那么p+i就是p[i]的地址,*(p+i)就是p[i]的值.

比如:int x[6],*p=x;p[i]==i[p]==*(p+i)==x[i]==i[x]==*(x+i),然后把int换成其它数据类型比如int[4],就变成原题了。

另外,不管x怎么定义,*(x+2)就是x[2],*(p+1)就是p[1],它们的数据类型是一样的

二维数组变量就是一个二级指针,取地址后得到一级指针,再取地址后才得到数.

所以 *(x+2) 是 x[2],不是x[0][2],x[0][2]是*(*x+2)

p是个二级指针,*(p+1)就是个一级指针,然后将一级指针赋给一个数就会报错了。

引用 7 楼 mewiteor 的回复:

Quote: 引用 3 楼 u012675103 的回复:

Quote: 引用 1 楼 mewiteor 的回复:

*(p+1)相当于p[1],其数据类型为int[2],int[2]赋值给int肯定会报错的。

原题里*(p+2)相当于p[2],应该等价于,x[2],题目问的是指向哪,相当于问*(p[2]),结果就是x[2][0]了

*(p+1)为什么会相当于p[1],int  (*p)[2]中的p是表示数组指针吧,即指向 一个   包含2个元素的   一维数组,如果是int *p[2],*p(+1)才是p[1]吧。。。。这里而x应该是一个 三行二列的二维数组的指针,如果是*(x+2)肯定是x[0][2],这里将二维数组的首地址强制赋给了一维数组的指针,本想验证一下,还是不太明白为什么会报错,能再说一下吗?谢谢~

*:当前地址指向的值.

[i]:当前地址指向的第i个元素的值

然而第i个元素的地址就是当前地址加上i*sizeof(TYPE)

p+i  C语言会自动转成 p+i*sizeof(TYPE)    (所以void*指针不能进行加减运算)

那么p+i就是p[i]的地址,*(p+i)就是p[i]的值.

比如:int x[6],*p=x;p[i]==i[p]==*(p+i)==x[i]==i[x]==*(x+i),然后把int换成其它数据类型比如int[4],就变成原题了。

另外,不管x怎么定义,*(x+2)就是x[2],*(p+1)就是p[1],它们的数据类型是一样的

二维数组变量就是一个二级指针,取地址后得到一级指针,再取地址后才得到数.

所以 *(x+2) 是 x[2],不是x[0][2],x[0][2]是*(*x+2)

p是个二级指针,*(p+1)就是个一级指针,然后将一级指针赋给一个数就会报错了。

噢,明白了,结贴。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值