滴滴笔试第一题为什么80%

话不多说,先看代码,这样总是会有数组越界的bug。。咋回事,大神来看看
public class SubMax { public static void main(String[] args) {
        Scanner in = new Scanner(System.in); while (in.hasNext()) { int n = in.nextInt(); int arr[] = new int[n]; int dp[] = new int[n]; for (int i = 0; i < n; i++) {
                arr[i] = in.nextInt();
                dp[i] = arr[i];
            } for (int i = 1; i < n; i++) {
                dp[i] = Math.max(arr[i]+dp[i-1],arr[i]);
            } long max = Integer.MIN_VALUE; for (int i = 0; i < n; i++) { if (max > arr[i])
                    max = arr[i];
            } for (int i = 0; i < n; i++) { if (max < dp[i])
                    max = dp[i];
            }
            System.out.println(max);
        }
    }
}


全部评论
全负数情况么考虑?
点赞 回复 分享
发布于 2016-09-07 13:25
要对n进行判断,如果n<=0,那么直接跳回输入
点赞 回复 分享
发布于 2016-09-06 21:45
叶神说测试数据有超过int的
点赞 回复 分享
发布于 2016-09-06 21:14
点赞 回复 分享
发布于 2016-09-06 21:14
全为负数考虑了么
点赞 回复 分享
发布于 2016-09-06 21:13

相关推荐

我的人生算是废了,23届裸辞空档一年,存款只能坚持几个月了,找不到像样的工作了,人生何去何从。
梦想是成为七海千秋:这大环境下为什么要裸辞呀,风险真的挺大的,而且社招的话23届没有太多的竞争力,不过既然已经裸辞了就不要焦虑慢慢找。
点赞 评论 收藏
分享
Southyeung:我说一下我的看法(有冒犯实属抱歉):(1)简历不太美观,给我一种看都不想看的感觉,感觉字体还是排版问题;(2)numpy就一个基础包,机器学习算法是什么鬼?我感觉你把svm那些写上去都要好一点。(2)课程不要写,没人看,换成获奖经历;(3)项目太少了,至少2-3个,是在不行把网上学习的也写上去。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务