C语言一维数组实参,二维数组形参问题,学的渣求大神告知
)答案是C,我很是费解。不是说数组名做参数,是传的首个元素地址咩,那s=f(a)搞出来的不就是6个数字的和吗?这个一维到二维到底怎么搞得!!!???大神行行好告诉我吧...
)答案是C,我很是费解。不是说数组名做参数,是传的首个元素地址咩,那s=f(a)搞出来的不就是6个数字的和吗?这个一维到二维到底怎么搞得!!!???大神行行好告诉我吧
展开
2个回答
展开全部
1 2 3 4 5 6 => 1 2 3
4 5 6
k = a[0][0] + a[0][1] + a[0][2] + a[1][1] + a[1][2] = 1 + 2 + 3 + 5 + 6 = 17.
不知道这个程序真的能通过编译么?c语言没有一维数组二维数组之分,反正都是存储在连续的存储空间里,当表示为a[i][j]时,只是它的取址方式变了,a[i][j] = *(a + i * 3 + j)。。。
所以也就相当于k = *(a + 0 * 3 + 0) + *(a + 0 * 3 + 1) + *(a + 0 * 3 + 2) + *(a + 1 * 3 + 1) + *(a + 1 * 3 + 2) = *(a + 0) + *(a + 1) + *(a + 2) + *(a + 4) + *(a + 5) = a[0] + a[1] + a[2] + a[4] + a[5]...
4 5 6
k = a[0][0] + a[0][1] + a[0][2] + a[1][1] + a[1][2] = 1 + 2 + 3 + 5 + 6 = 17.
不知道这个程序真的能通过编译么?c语言没有一维数组二维数组之分,反正都是存储在连续的存储空间里,当表示为a[i][j]时,只是它的取址方式变了,a[i][j] = *(a + i * 3 + j)。。。
所以也就相当于k = *(a + 0 * 3 + 0) + *(a + 0 * 3 + 1) + *(a + 0 * 3 + 2) + *(a + 1 * 3 + 1) + *(a + 1 * 3 + 2) = *(a + 0) + *(a + 1) + *(a + 2) + *(a + 4) + *(a + 5) = a[0] + a[1] + a[2] + a[4] + a[5]...
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询