杭电OJ判断Runtime Error (ACCESS_VIOLATION)

滚弹开花 2017-08-28 10:30:55
程序在cb上运行正常,提交到OJ上就说这个错误Runtime Error (ACCESS_VIOLATION)。希望各位帮忙指点。
这个是杭电OJ1003道题
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
int integer[1000];
int CaseNumber ; ///情况数
int IntegerNumber ;///每一种情况包含的数字个数
int MaxSum[1000] ;
int Max ;
int start ;
int end ;
int i , j , k , q ;

///数组初始化
memset(integer,0,1000);
memset(MaxSum,0,1000);

//printf("input the case number:");
scanf("%d",&CaseNumber);///输入例子数
for(i=1;i<=CaseNumber;i++)
{
start = 0 ;
scanf("%d",&IntegerNumber); ///输入情况内部数字个数
for(j=1;j<=IntegerNumber;j++)
{
scanf("%d",&integer[j]); ///输入数组
if( start == 0 && integer[j] >= 0 )///确定第一个大于等于零的数作为起始位
start = j ;
}

///应对全是负数情况
if (start == 0)
{
start = 1 ;
end = 1 ;
Max = integer[1] ;
}
else
{
MaxSum[start-1] = 0 ;///计算从第一项开始每往后加一个数的和的数组
for(k=start;k<=IntegerNumber;k++)
MaxSum[k] = MaxSum[k-1] + integer[k] ;

Max = MaxSum[start] ;///求出和数组中的最大值
end = start ;
for(q=start;q<=IntegerNumber;q++)
{
if(MaxSum[q+1]>Max)
{
Max = MaxSum[q+1] ;
end = q+1 ;///更新最后位置数
}
}
}
printf("Case %d:\n",i);///输出Case #:
printf("%d %d %d\n\n",Max,start,end);
}
return 0 ;
}
...全文
480 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
502203305 2017-09-04
  • 打赏
  • 举报
回复
可以去搜索最大组数组的问题,http://blog.csdn.net/liufeng_king/article/details/8632430这个博客你可以看一看,大概就会懂了
kugeniha 2017-08-28
  • 打赏
  • 举报
回复
最好把题目说出 来
自信男孩 2017-08-28
  • 打赏
  • 举报
回复
or(j=1;j<=IntegerNumber;j++)
        {
            scanf("%d",&integer[j]); ///输入数组
            if( start == 0 && integer[j] >= 0 )///确定第一个大于等于零的数作为起始位
                start = j ;
        }
这个地方有可能导致越界,比如输入的IntegerNumber为1000,这个地方就越界了。下标从0开始,
or(j=0;j<IntegerNumber;j++)
        {
            scanf("%d",&integer[j]); ///输入数组
            if( start == 0 && integer[j] >= 0 )///确定第一个大于等于零的数作为起始位
                start = j ;
        }
另外,对于大数组,建议定义成全局的或者静态变量。栈上的空间是稀少和宝贵的,不建议占用栈上的过多空间。
 static int integer[1000];
    int CaseNumber ; ///情况数
    int IntegerNumber ;///每一种情况包含的数字个数
    static int MaxSum[1000] ;
赵4老师 2017-08-28
  • 打赏
  • 举报
回复
在占用内存空间较大的局部数组声明的前面加static将其从堆栈数据段挪到全局数据段即可避开因局部数组大小超过默认堆栈大小1MB造成程序不能正常运行的问题。

69,371

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧