C语言生成用户输入大小的数组

int main()
{
	int i,j, m, n;	
	printf("Please input the number of m and n;");
	scanf("%d %d", &m, &n);
	int *p = (int*)malloc(sizeof(int) * m * n);//p是一个指向int形的指针,malloc函数返回类型为void*,即指向void形的指针使用int*类型进行强制类型转换。动态分配内存以实现用户输入数组大小分配数组内存的效果
	for (i = 0; i < m; i++)
	{
		for(j=0;j<n;j++)
		{
			scanf("%d", (p + m * i+j));
		}
	}	//printf("%d\n", *(p + 3));
	for (i = 0; i < m; i++)
	{
		for (j = 0; j < n; j++)
		{
			printf("%d ", *(p + i * m + j));
		}
		printf("\n");
	}
	return 0;
}

代码如上,写一些特定的组合就会出现奇怪的结果,但输入其他组合也会显示正确,到底是为什么?

错误输出

正确输出

scanf("%d", (p + m * i+j));和printf("%d ", *(p + i * m + j));这里计算错误了,应该是

scanf("%d", (p + n * i+j));和printf("%d ", *(p + i * n + j));

完整代码如下,如有帮助,请采纳一下,谢谢。

#include <stdio.h>
#include <stdlib.h>
int main()
{
	int i,j, m, n;	
	printf("Please input the number of m and n;");
	scanf("%d %d", &m, &n);
	int *p = (int*)malloc(sizeof(int) * m * n);//p是一个指向int形的指针,malloc函数返回类型为void*,即指向void形的指针使用int*类型进行强制类型转换。动态分配内存以实现用户输入数组大小分配数组内存的效果
	for (i = 0; i < m; i++)
	{
		for(j=0;j<n;j++)
		{
			scanf("%d", (p + n* i+j));  //修改1
		}
	}	//printf("%d\n", *(p + 3));
	for (i = 0; i < m; i++)
	{
		for (j = 0; j < n; j++)
		{
			printf("%d ", *(p + i * n + j));//修改2
		}
		printf("\n");
	}
	free(p); //修改3,释放内存空间
	return 0;
}

换行的时候错了,假如n=2,m=3时候,在第一行最后一个数和第二行第一个数的时候,i=0 j=2 m(2)*i(0)+j(2)=2和i=1 j=0 m(2)*i(1)+j(0)=2的时候指向是同一个地址,改为下面那样就好了

int main()
{
	int i,j, m, n;	
	printf("Please input the number of m and n;");
	scanf("%d %d", &m, &n);
	int *p = (int*)malloc(sizeof(int) * m * n);//p是一个指向int形的指针,malloc函数返回类型为void*,即指向void形的指针使用int*类型进行强制类型转换。动态分配内存以实现用户输入数组大小分配数组内存的效果
	for (i = 0; i < m; i++)
	{
		for(j=0;j<n;j++)
		{
			scanf("%d", (p + n * i+j)); //上一行数*每一行的列数+当前列的列数
		}
	}	//printf("%d\n", *(p + 3));
	for (i = 0; i < m; i++)
	{
		for (j = 0; j < n; j++)
		{
			printf("%d ", *(p + i * n + j));
		}
		printf("\n");
	}
	return 0;
}