m0_56197713
2021-06-03 22:50
采纳率: 100%
浏览 28

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

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

错误输出

正确输出

  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

2条回答 默认 最新

  • qfl_sdu 2021-06-03 23:06
    已采纳

    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;
    }
    
    已采纳该答案
    打赏 评论
  • MagicKingC 2021-06-03 23:35

    换行的时候错了,假如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;
    }
    打赏 评论

相关推荐 更多相似问题