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

连续子数组的最大乘积

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);
    }
}
全部评论

相关推荐

10-17 10:05
已编辑
北华大学 全栈开发
牛客872465272号:掉头发了哥
点赞 评论 收藏
分享
11-15 18:39
已编辑
西安交通大学 Java
全村最靓的仔仔:卧槽,佬啥bg呢,本也是西交么
点赞 评论 收藏
分享
评论
3
收藏
分享
牛客网
牛客企业服务