鱼C论坛

 找回密码
 立即注册
查看: 1349|回复: 10

[已解决]动态二维数组

[复制链接]
发表于 2021-1-4 16:36:19 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
哪里不对呢?
  1. #include<stdio.h>
  2. #include<stdlib.h>
  3. int main()
  4. {
  5.     int i,j,N;
  6.     scanf("%d",&N);
  7.     int **p;
  8.     p=(int**)malloc(N*sizeof(int*));
  9.     for(i=0;i<N;i++)
  10.     {
  11.         *(p+i)=(int *)malloc(N*sizeof(int));
  12.     }
  13.     for(i=0;i<N;i++)
  14.     {
  15.         for(j=0;j<N;j++)
  16.         {
  17.             scanf("%d",&p[i][j]);
  18.         }
  19.     }
  20.     int sum;
  21.     for(i=0,j=N-1;i<N,j>=0;i++,j--)
  22.     {
  23.         sum+=p[i][j];
  24.     }
  25.     for(i=0,j=0;i<N,j<N;i++,j++)
  26.     {
  27.         sum+=p[i][j];
  28.     }
  29.     sum-=p[N/2][N/2];
  30.     printf("%d",sum);
  31.     return 0;
  32. }
复制代码
最佳答案
2021-1-4 16:57:45
一世轻尘 发表于 2021-1-4 16:51
嗯,不过好像还有一点点问题

没有free内存,造成内存泄露。
1.png
2.png
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-1-4 16:41:22 | 显示全部楼层
sum没有初始化

  1. int sum = 0;
复制代码

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-1-4 16:51:35 | 显示全部楼层

嗯,不过好像还有一点点问题
3.png
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-1-4 16:56:16 | 显示全部楼层
本帖最后由 jackz007 于 2021-1-4 17:19 编辑

        此题样例输入的输出分明是 30,怎么会是 25 呢?
  1. #include<stdio.h>
  2. #include<stdlib.h>
  3. int main()
  4. {
  5.         int i , j , N , ** p , s                                              ;
  6.         scanf("%d" , & N)                                                     ;
  7.         p = (int **) malloc(N * sizeof(int *))                                ;
  8.         for(i = 0 ; i < N ; i ++) * (p + i) = (int *) malloc(sizeof(int) * N) ;
  9.         for(s = i = 0 ; i < N ; i ++) {
  10.                 fflush(stdin)                                                 ;
  11.                 for(j = 0 ; j < N ; j ++) scanf("%d" , & p[i][j])             ;
  12.                 s += p[i][i]                                                  ;
  13.                 if(N - 1 - i != i) s += p[i][N - 1 - i]                       ;
  14.         }
  15.         printf("%d\n" , s)                                                    ;
  16.         for(i = 0 ; i < N ; i ++) free(* (p + i))                             ;
  17.         free(p)                                                               ;
  18. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-1-4 16:57:45 | 显示全部楼层    本楼为最佳答案   
一世轻尘 发表于 2021-1-4 16:51
嗯,不过好像还有一点点问题

没有free内存,造成内存泄露。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-1-4 16:58:59 | 显示全部楼层
jackz007 发表于 2021-1-4 16:56
此题样例输入的输出分明是 30,怎么会是 25 呢?

中间那个数只能用一次,两个对角线重复了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-1-4 17:01:31 | 显示全部楼层
xieglt 发表于 2021-1-4 16:57
没有free内存,造成内存泄露。

还是不行,哎,我已经被它折磨好几天了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-1-4 17:04:31 | 显示全部楼层
xieglt 发表于 2021-1-4 16:57
没有free内存,造成内存泄露。

找到问题了,只有奇数的时候应该吧中间的减去,偶数的时候两对角线没有重复
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-1-4 17:19:04 From FishC Mobile | 显示全部楼层
for(i=0;i<N;i++)
{
sum += p[i][i];
if(i!=N-i-1)
sum+=p[i][N-i-1];
}
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-1-4 17:20:51 | 显示全部楼层
一世轻尘 发表于 2021-1-4 17:04
找到问题了,只有奇数的时候应该吧中间的减去,偶数的时候两对角线没有重复

     4 楼的代码改了,看看能否过测试平台
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-1-4 17:52:08 | 显示全部楼层
jackz007 发表于 2021-1-4 17:20
4 楼的代码改了,看看能否过测试平台

过了过了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-5-3 05:09

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表