2301_81331163 2023-12-25 14:32 采纳率: 100%
浏览 5
已结题

二维前缀和的问题求教导

这个程序有什么问题

#include <stdio.h>
int main(){
    int n,m,k,x1,x2,y1,y2,sum;
    int a[1001][1001]={0},temp[1001][1001]={0};
    scanf("%d %d %d",&n,&m,&k);
    for(int i=1;i<=n;i++){
        for(int j=1;j<=m;j++){
            scanf("%d",&a[i][j]);
            temp[i][j]=temp[i-1][j]+temp[i][j-1]-temp[i-1][j-1]+a[i][j];
        }
    }
    for(int i=0;i<k;i++){
        scanf("%d %d %d %d",&x1,&y1,&x2,&y2);
        sum=temp[x2][y2]-temp[x1-1][y2]-temp[x2][y1-1]+temp[x1-1][y1-1];
        printf("%d\n",sum);
    }
    return 0;
}

  • 写回答

2条回答 默认 最新

  • 柯本 2023-12-25 14:40
    关注

    程序语法上没有问题,但有一个致命问题,因为你的大数组变量是自动变量,它分配在栈上,而系统的栈有限止的(不同系统/不同编译器各有不同),一般情况下,你的栈溢出了
    解决,最简单的将数组作为全局的(它在堆上),且不用初始化了(它会自动填0的)
    也就是将

      int a[1001][1001],temp[1001][1001];
    

    写在main() 的前面
    至于程逻辑上,就要看你具体的要求了

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 1月11日
  • 已采纳回答 1月3日
  • 创建了问题 12月25日

悬赏问题

  • ¥15 Windows Script Host 无法找到脚本文件"C:\ProgramData\Player800\Cotrl.vbs”
  • ¥15 matlab自定义损失函数
  • ¥15 35114 SVAC视频验签的问题
  • ¥15 impedancepy
  • ¥15 求往届大挑得奖作品(ppt…)
  • ¥15 如何在vue.config.js中读取到public文件夹下window.APP_CONFIG.API_BASE_URL的值
  • ¥50 浦育平台scratch图形化编程
  • ¥20 求这个的原理图 只要原理图
  • ¥15 vue2项目中,如何配置环境,可以在打完包之后修改请求的服务器地址
  • ¥20 微信的店铺小程序如何修改背景图