为此,必须清醒地知道,所谓二维数组,其元素在内存中依然是以一维的方式存放的。说实话,二维数组本质上是不存在的。
既然如此,那么,“构造”一个所谓的二维数组,只要能提供足够实用的函数(工具)操作这个二维数组就可以了。
综上,接受由用户决定的二维数组行、列值,申请一个一维数组的空间,按照二维数组方式进行定位和操作就可以了。
为简便起见,我用如下定义,你可以更改里面的类型,以适应自己的需要:
typedef int USER_TYPE
// 定义一个控制二维数组(矩阵)的“控制头”,由三个成员组成
typedef struct MATRIX
{
USER_TYPE *data // 真正用来存储二维数组元素的空间
int Row // 二维数组行数
int Col // 二维数组列数
}MATRIX
MATRIX *initMatrix(int row, int col) // 初始化二维数组
USER_TYPE getElementAt(MATRIX matrix, int i, int j)// 取得指定下标的元素
void setElementAt(MATRIX matrix, int i, int j, USER_TYPE val)// 给指定下标的元素赋值
void destroyMatrix(MATRIX *matrix)// 销毁二维数组
void destroyMatrix(MATRIX *matrix)
{
free(matrix->data)
free(matrix)
}
void setElementAt(MATRIX matrix, int i, int j, USER_TYPE val)
{
matrix.data[i*matrix + j] = val
}
USER_TYPE getElementAt(MATRIX matrix, int i, int j)
{
return matrix.data[i*matrix.Col + j]
}
MATRIX *initMatrix(int row, int col)
{
MATRIX *mp
mp = (MATRIX *)malloc(sizeof(MATRX))
mp->data = (USER_TYPE *)malloc(sizeof(USER_TYPE) * row * col)
mp->Row = row
mp->Col = col
return mp
}
把上面的函数当成工具,完成二维数组初始化、赋值、取值等一系列操作,如果需要比较,还需要编写比较的函数。
你的空间申请有问题,这是帮你改好后的,你可以运行看看。不着调是否帮上你了,如果OK还望采纳,和而后~~ #include <stdio.h>#include <stdlib.h>void main()
{
int n,i=0,j=0
int **p
printf("?????????:")
scanf("%d",&n)
//p=(int**)malloc(sizeof(int)*n*n)
p=(int**)malloc(sizeof(int*)*n)
for(i=0i<ni++)
{
p[i]=(int*)malloc(sizeof(int)*n)for(j=0j<nj++)
{
scanf("%d",&p[i][j])
//printf("%d",p[i][j])
}
}for(i=0i<ni++)
{
for(j=0j<nj++)
{
printf("%d ",p[i][j])
}
printf("\n")
}
system("pause")
}