题解 | #连续子数组的最大乘积#

连续子数组的最大乘积

http://www.nowcoder.com/practice/fd8c819c07c9493887bfac8549c119f4

import java.io.*;
import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(new BufferedInputStream(System.in));
        int n = scan.nextInt();
        int[] nums = new int[n];
        for (int i = 0; i < n; i++)
            nums[i] = scan.nextInt();
        int preMax = 1;
        int preMin = 1;
        int res = (int)-1e9;
        for (int num: nums) {
            int a = preMax * num, b = preMin * num;
            preMax = Math.max(Math.max(a, b), num);
            preMin = Math.min(Math.min(a, b), num);
            res = Math.max(preMax, res);
        }
        System.out.println(res);
    }
}
全部评论

相关推荐

猪扒已出闸:方向不够聚焦,看不出来是想找什么方向的工作
点赞 评论 收藏
分享
头像
11-21 11:39
四川大学 Java
是红鸢啊:忘了还没结束,还有字节的5k 违约金
点赞 评论 收藏
分享
评论
3
收藏
分享
牛客网
牛客企业服务