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;
}