滴滴笔试第一题为什么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-06 21:13
点赞 回复 分享
发布于 2016-09-06 21:14
叶神说测试数据有超过int的
点赞 回复 分享
发布于 2016-09-06 21:14
要对n进行判断,如果n<=0,那么直接跳回输入
点赞 回复 分享
发布于 2016-09-06 21:45
全负数情况么考虑?
点赞 回复 分享
发布于 2016-09-07 13:25

相关推荐

服从性笔试吗,发这么多笔,现在还在发。
蟑螂恶霸zZ:傻 x 公司,发两次笔试,两次部门匹配挂,
投递金山WPS等公司10个岗位 >
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
10-05 10:13
已编辑
HHHHaos:让这些老登来现在秋招一下,简历都过不去
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
11-20 19:57
已编辑
某大厂 golang工程师 23.0k*16.0, 2k房补,年终大概率能拿到
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务