定义一个指针类型p,指向3行4列的整形二维数组
inta[3][4];int(*p)[3][4]=&a;报错严重性错误C2040“p”:“int(*)[3][4]”与“int*”的间接寻址级别不同...
int a[3][4];int(*p)[3][4]=&a;报错严重性 错误 C2040 “p”:“int (*)[3][4]”与“int *”的间接寻址级别不同
展开
1个回答
展开全部
在内存中实际上没有二维数组的概念,可以完全看成一维数组。求最大值,可以使用假设法,假设第1个元素为最大值,然后遍历数组,通过比较求出最大值即可。找到在1维数组中的维数再转换成二维数组中的维数即可。
#include <stdio.h>
int main()
{
int a[3][4] = {
{92,108,3000,1},
{100,101,102,103},
{799,10000,20, 0}
};
int *pstart = &a[0][0];
int max = a[0][0];
int pos = 0;
for (int inx=0; inx!=12; ++inx) {
if (*(pstart+inx) > max) max = *(pstart+inx), pos = inx;
}
printf("最大值是:%d\t其所在位置:a[%d][%d]\n", max, pos / 4, pos % 4);
return 0;
}
#include <stdio.h>
int main()
{
int a[3][4] = {
{92,108,3000,1},
{100,101,102,103},
{799,10000,20, 0}
};
int *pstart = &a[0][0];
int max = a[0][0];
int pos = 0;
for (int inx=0; inx!=12; ++inx) {
if (*(pstart+inx) > max) max = *(pstart+inx), pos = inx;
}
printf("最大值是:%d\t其所在位置:a[%d][%d]\n", max, pos / 4, pos % 4);
return 0;
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询