c语言中*(*(p+1)+2) 什么意思?具体怎么表示的? 请教一个c语言题目,后面那个*(*(p+2)+1)什么意思?...

c\u8bed\u8a00\u4e2d*(*(p+1)+2) \u4ec0\u4e48\u610f\u601d\uff1f\u5177\u4f53\u600e\u4e48\u8868\u793a\u7684\uff1f

\u4ee5\u8fd9\u79cd\u5199\u6cd5\u6765\u770b p\u81f3\u5c11\u662f**\u578b \u5373\u6307\u5411\u6307\u9488\u7684\u6307\u9488
\u6bd4\u5982int **
\u8fd9\u53e5\u8bdd\u4ee3\u8868\u7684\u542b\u4e49\u662f
\u5bf9p\u53f3\u79fb\u4e00\u4e2a\u5355\u4f4d
\u53d6\u503c
\u5bf9\u8be5\u503c\u6240\u4ee3\u8868\u7684\u5730\u5740\u53f3\u79fb2\u4e2a\u5355\u4f4d
\u5bf9\u8be5\u5730\u5740\u53d6\u503c

\u6307\u9488\u79fb\u52a8\u82e5\u5e72\u4e2a\u5355\u4f4d\uff0c\u6240\u589e\u52a0\u7684\u5730\u5740\u503c\u53d6\u51b3\u4e8e\u6307\u9488\u7684\u7c7b\u578b
\u901a\u7528\u516c\u5f0f\u4e3a T *p; p+n = p\u7684\u503c+ n*\uff08sizeof(T)\uff09

int (*p)[2]=a;\u5c31\u662f\u5b9a\u4e49\u4e86\u4e00\u4e2a\u6307\u54112\u7ef4\u6570\u7ec4\u7684\u7684\u6307\u9488\uff0cp\u81ea\u589e\u8de8\u5ea6\u662f2\u3002
\u5728\u8fd9\u91ccp\u5c31\u662f\u884c\u6307\u9488
p\u7684\u503c\u5c31\u662f\u6307\u5411\u6570\u7ec4{10,20}\u7684\u6307\u9488\u3002
\u6240\u4ee5p+2\u5c31\u662f\u6307\u5411\u6570\u7ec4{50,80}\u7684\u6307\u9488\uff08p\u81ea\u589e\u8de8\u5ea62\uff09\u3002
\u6240\u4ee5*(p+2)+1\u5c31\u662f&a[2][1]\u7684\u5730\u5740\u3002
\u6240\u4ee5*\uff08*\uff08p+2\uff09+1\uff09\u5c31\u662f80\u3002

*(*(p+1)+2)为二维数组用指针表示的形式,相当于数组元素num[1][2]

二维数组本质上是以数组作为数组元素的数组,即“数组的数组”,类型说明符 数组名[常量表达式][常量表达式]。二维数组又称为矩阵,行列数相等的矩阵称为方阵。

对称矩阵a[i][j] = a[j][i],对角矩阵:n阶方阵主对角线外都是零元素。

二维数组A[m][n],这是一个m行,n列的二维数组。设a[p][q]为A的第一个元素,即二维数组的行下标从p到m+p,列下标从q到n+q,元素a[i][j]的地址计算方法如下:

按“行优先顺序”存储时,地址计算为:LOC(a[i][j]) = LOC(a[p][q]) + ((i − p) * n + (j − q)) * t

按“列优先顺序”存储时,地址计算为:LOC(a[i][j]) = LOC(a[p][q]) + ((j − q) * m + (i − p)) * t

存放该数组至少需要的单元数为(m-p+1) * (n-q+1) * t 个字节


扩展资料:

指向二维数组的指针变量设二维数组为a[m][n]

设有整型二维数组a[3][4]如下:

1000 1001 1002 1003

1004 1005 1006 1007

1008 1009 1010 1011

设数组a的首地址为1000,各下标变量的首地址及其值如上列出。

C语言允许把一个二维数组分解为多个一维数组来处理。因此数组a可分解为三个一维数组,即a[0],a[1],a[2]。每一个一维数组又含有四个元素。例如a[0]数组,含有a[0][0],a[0][1],a[0][2],a[0][3]四个元素。

数组及数组元素的地址表示如下:a是二维数组名,也是二维数组0行的首地址,等于1000。a[0]是第一个一维数组的数组名和首地址,因此也为1000。

*(a+0)或*a是与a[0]等效的,它表示一维数组a[0]0号元素的首地址。也为1000。&a[0][0]是二维数组a的0行0列元素首地址,同样是1000。因此,a,a[0],*(a+0),*a,&a[0][0]是相等的。

同理,a+1是二维数组1行的首地址,等于1004。a[1]是第二个一维数组的数组名和首地址,因此也为1004。&a[1][0]是二维数组a的1行0列元素地址,也是1004。

因此a+1,a[1],*(a+1),&a[1][0]是等同的。由此可得出:a+i,a[i],*(a+i),&a[i][0]是等同的。此外,&a[i]和a[i]也是等同的。因为在二维数组中不能把&a[i]理解为元素a[i]的地址,不存在元素a[i]。

C语言规定,它是一种地址计算方法,表示数组a第i行首地址。由此,我们得出:a[i],&a[i],*(a+i)和a+i也都是等同的。

另外,a[0]也可以看成是a[0]+0是一维数组a[0]的0号元素的首地址,而a[0]+1则是a[0]的1号元素首地址,由此可得出a[i]+j则是一维数组a[i]的j号元素首地址,它等于&a[i][j]。

由a[i]=*(a+i)得a[i]+j=*(a+i)+j,由于*(a+i)+j是二维数组a的i行j列元素的首地址。该元素的值等于*(*(a+i)+j)。

参考资料来源:百度百科-二维数组

参考资料来源:百度百科-数组指针



举例:int p[2][3];这是个二维数组2行3列,而用指针形式*(*(p+1)+2)表示的是p[1][2]这个元素,即:*(p+1)指向的是第一行(p[1]),*(p+1)+2表示的是第一行第二列的地址,而*(*(p+1)+2)就是取第一行第二列的内容也就是p[1][2]这个元素

推荐你去c语言贴吧去提问,哪里有专业的人会告诉你真的,不适合在知道上问

去查“指向指针的指针”

以地址p+1的值,再加上2组成的地址里面的值

好拗口啊,呵呵

  • c.p.鏄粈涔堟剰鎬(C璇█鎸囬拡##p鏄粈涔堟剰鎬)
    绛旓細p*=i涔熷氨鏄痯=p*i,鍗冲皢鍘熷鐨刾鍊间笌i鍊肩浉涔橈紝缁撴灉璧嬪肩粰p銆C璇█涓绫讳技鐨勭鍙疯繕鏈+=,-=,/=,%=,^=,|=,&=绛夌瓑銆侰璇█鎸囬拡**p鏄粈涔堟剰鎬 p锛氫簩绾ф寚閽堬紝琛ㄧずp鎵鎸囧悜鐨勫湴鍧閲岄潰瀛樻斁鐨勬槸涓涓寚鍚戠被鍨嬬殑鎸囬拡銆*p锛氫竴绾ф寚閽堬紝琛ㄧずp鎵鎸囧悜鐨勫湴鍧閲岄潰瀛樻斁鐨勬槸涓涓被鍨嬬殑鍊笺
  • C璇█涓涓や釜*鏄粈涔堟剰鎬?姣斿int**p
    绛旓細杩欐椂,*p浠h〃杩欎釜鎸囬拡鏁扮粍鐨棣栧厓绱,涔熷氨鏄竴涓竴缁存寚閽;**p浠h〃杩欎釜涓缁存寚閽堟寚鍚戠殑鏁版嵁銆 鐝姞瑗2011 | 鍙戝竷浜2013-04-13 涓炬姤| 璇勮 6 5 鎸囧悜鎸囬拡鐨勬寚閽堛 杩介棶 閭f剰鎬濆氨鏄,鏈変竴涓暟缁刟[i]={1,2,3,4,5,路路路} 鎸囬拡**p,p=a[0銆,杩欎釜**p灏辨槸鎸囧悜a[0]鍜宎[1]鐨勫,缁撴灉**p=a[1]鍚?杩...
  • C璇█涓,鎸囬拡(*p)[]杩欐槸浠涔?鎬庝箞鐢?
    绛旓細(*p)[];杩欐槸瀹氫箟浜嗕竴涓暟缁勬寚閽 p[] 鏄寚閽堟暟缁勶紝(*p)[]鏄暟缁勬寚閽 渚嬪锛歝har *p[5] 鏄寚閽堟暟缁勶紝鏁扮粍鏈5涓厓绱狅紝姣忎釜鍏冪礌閮芥槸鎸囬拡 char (*p)[5]鏄暟缁勬寚閽堬紝p鎸囧悜鍚湁5涓厓绱犵殑鏁扮粍
  • c璇█ int(*p)[2]鍜宨nt *p [2]鏈変粈涔堝尯鍒?
    绛旓細p[1] = b;for(int i = 0; i < 3; i++) printf("%d\n", *p[0] + i);for(int i = 0; i < 4; i++)printf("%d\n", *p[1] + i);} 锛2锛瀵逛簬銆int (*p)[2], 瀹冪浉褰撲簬涓涓簩缁存暟缁鐨鐢ㄦ硶锛屽彧鏄畠鏄竴涓猲琛2鍒楃殑鏁扮粍锛屽彲浠ヨ繖鏍锋潵鐢細include <stdio.h> int main...
  • C璇█浜岀淮鏁扮粍鎸囬拡鍙橀噺鏄粈涔,int (*p)[2]浠涔堟剰鎬
    绛旓細閲囩撼鐜:73% 鎿呴暱: 鑰冪爺 QQ椋炶溅 鍏朵粬缂栫▼璇█ 鏁版嵁缁撴瀯鍙婄畻娉 C/C++ 鍏朵粬鍥炵瓟 int (*p)[4] 瀹氫箟浜嗕竴涓寚閽坧,鎸囧悜涓涓4涓厓绱犵殑鏁扮粍銆傚彧鏄畾涔変竴涓寚閽,鎸囧悜4涓厓绱犵殑鏁扮粍int *p[4]瀹氫箟浜嗕竴涓暟缁勬寚閽坧[4],p鐨姣忎釜鍏冪礌鎸囧悜涓涓暣鍨嬬殑鏁版嵁銆傚氨鏄暟缁閲岄潰淇濆瓨鐨勬槸鎸囬拡(1)int* p[2] 鏄竴涓寚鍚慽nt鍨...
  • 鍦c璇█涓*(p+2)鍜*p+2鏈変粈涔堜笉鍚
    绛旓細浜屻佺敤娉曚笉鍚 渚嬪锛氭湁鏁扮粍a:1 2 3 4 5 p=&a;閭d箞锛(p+2)=3,*p+2=3 p灏辩瓑浜1.*(p+X)灏辨槸灏嗘寚閽堢Щx鐨浣嶇疆銆備笁銆佺敤閫斾笉鍚 1銆*p[ ]鍦╩ain鍑芥暟鐨勫弬鏁颁腑鏈変娇鐢ㄥ埌锛屽叾涓殑 char *argv[]鐨刟rgv灏辨槸涓涓寚閽堟暟缁勶紝鐢ㄦ潵瀛樺偍鍑芥暟璋冪敤鏃朵紶杩涙潵鍙彉涓暟鐨勫弬鏁 int main(int argc, char ...
  • c璇█涓*p+1鍜*(p+1)鏈変粈涔堜笉鍚
    绛旓細C璇█涓锛*p 鍜宲閮藉父鐢ㄥ湪鎸囬拡褰撲腑琛ㄧず涓涓寚閽堝彉閲忥紝*p 鍜宲鐨勫尯鍒細1銆佽〃绀虹殑鍚箟涓嶅悓 p琛ㄧず姝ゆ寚閽堟寚鍚戠殑鍐呭瓨鍦板潃涓瓨鏀剧殑鍐呭銆俻琛ㄧず涓涓寚閽堝彉閲忕殑鍚嶅瓧锛屾寚姝ゆ寚閽堝彉閲忔墍鎸囧悜鐨勫唴瀛樺湴鍧銆2銆佽緭鍑虹殑鏍煎紡涓嶅悓 p涓鑸槸涓涓拰鎸囬拡绫诲瀷涓鑷寸殑鍙橀噺鎴栬呭父閲忋俻杈撳嚭鐨勬槸涓涓16杩涘埗鏁帮紝 杈撳嚭涓涓寚閽堢殑鍦板潃...
  • *(p[])鍦c璇█涓鏄粈涔堟剰鎬
    绛旓細濡傛灉[]娌℃湁浠讳綍鏁版嵁鐨璇 閭d箞杩欎釜鍙兘鐢ㄥ湪鍑芥暟鍙傛暟涓 绛夊悓浜 *p[] 绛夋晥浜**p 涔熷氨鏄簩绾ф寚閽堛傚鏋淸]褰撲腑鏈夋暣鍨嬪硷紝 姣斿*(p[i])閭d箞 灏辨槸鍏堝彇p[i]鐨勫硷紝杩欎釜鏄竴涓寚閽堛 鐒跺悗瀵硅繖涓寚閽堝彇鍊笺傜瓑鏁堜簬 p[i][0]
  • 璇锋暀涓涓c璇█棰樼洰,鍚庨潰閭d釜*(*(p+2)+1)浠涔堟剰鎬?杩欓鎬庝箞鍐
    绛旓細int (*p)[2]=a;灏辨槸瀹氫箟浜嗕竴涓寚鍚2缁存暟缁鐨勭殑鎸囬拡锛宲鑷璺ㄥ害鏄2銆傚湪杩欓噷p灏辨槸琛屾寚閽 p鐨勫煎氨鏄寚鍚戞暟缁剓10,20}鐨勬寚閽堛傛墍浠+2灏辨槸鎸囧悜鏁扮粍{50,80}鐨勬寚閽堬紙p鑷璺ㄥ害2锛銆傛墍浠*(p+2)+1灏辨槸&a[2][1]鐨勫湴鍧銆傛墍浠*锛*锛坧+2锛+1锛灏辨槸80銆
  • 鍦C璇█涓*(*p+1)琛ㄧず浠涔堟剰鎬
    绛旓細p鏄釜鎸囬拡鐨勬寚閽堛俻锛 鏄寚閽p閲岄潰鐨鍐呭锛屽畠鏈韩涔熸槸涓寚閽 p+1锛屾寚鍚*p鐨勪笅涓涓湴鍧 (*p + 1)锛*p鐨勪笅涓涓湴鍧閲岄潰鐨勫唴瀹
  • 扩展阅读:c++教程 ... c#语言翻译器 ... c++和python先学哪个 ... c++和java哪个好就业 ... c++编程 ... c#是什么 ... c++中<< ... c视频教程 ... c十十语言 ...

    本站交流只代表网友个人观点,与本站立场无关
    欢迎反馈与建议,请联系电邮
    2024© 车视网