源小林 2022-08-22 11:16 采纳率: 100%
浏览 59
已结题

long long数组开在main内出现无法输入的情况

以下是可以正常运行的C++代码程序:

#include<iostream>
#include<cstring>
const int maxn = 1510;
long long minnum[maxn][maxn];
using namespace std;
int main() {
    int n;
    cin>>n;
    for(int i = 0; i < n; i++)
        for(int j = 0; j <= i; j++)
            cin>>minnum[i][j];
    for(int i = n-2; i >= 0; i--)
        for(int j = 0; j <= i; j++)
            if(minnum[i+1][j] < minnum[i+1][j+1])
                minnum[i][j] = minnum[i][j] + minnum[i+1][j];
            else minnum[i][j] = minnum[i][j] + minnum[i+1][j+1];
    cout<<minnum[0][0];
    return 0;
}    

img

但是将long long minnum[maxn][maxn]开在main函数内,并加一句”memset(minnum, 0, sizeof(minnum));"在Windows下运行,会出现无法输入的情况,这是为什么?

#include<iostream>
#include<cstring>
const int maxn = 1510;
using namespace std;
int main() {
    long long minnum[maxn][maxn];
    memset(minnum, 0, sizeof(minnum));
    int n;
    cin>>n;
    for(int i = 0; i < n; i++)
        for(int j = 0; j <= i; j++)
            cin>>minnum[i][j];
    for(int i = n-2; i >= 0; i--)
        for(int j = 0; j <= i; j++)
            if(minnum[i+1][j] < minnum[i+1][j+1])
                minnum[i][j] = minnum[i][j] + minnum[i+1][j];
            else minnum[i][j] = minnum[i][j] + minnum[i+1][j+1];
    cout<<minnum[0][0];
    return 0;
}    

  • 写回答

3条回答 默认 最新

  • 快乐鹦鹉 2022-08-22 11:17
    关注

    临时变量太大了。
    放在main函数里,long long minnum[maxn][maxn]数组就是个局部变量,局部变量没有这么大空间给你,所以失败了
    放在main函数之上,就是全局变量,全局变量空间大,能够分配给你这个空间,所以OK

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

报告相同问题?

问题事件

  • 系统已结题 8月30日
  • 已采纳回答 8月22日
  • 修改了问题 8月22日
  • 创建了问题 8月22日

悬赏问题

  • ¥15 微信公众平台自制会员卡可以通过收款码收款码收款进行自动积分吗
  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab
  • ¥20 重新写的代码替换了之后运行hbuliderx就这样了
  • ¥100 监控抖音用户作品更新可以微信公众号提醒
  • ¥15 UE5 如何可以不渲染HDRIBackdrop背景
  • ¥70 2048小游戏毕设项目
  • ¥20 mysql架构,按照姓名分表
  • ¥15 MATLAB实现区间[a,b]上的Gauss-Legendre积分
  • ¥15 delphi webbrowser组件网页下拉菜单自动选择问题