Java教程

csp题集《最大的矩形》-Java

本文主要是介绍csp题集《最大的矩形》-Java,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

 

思路:贪心算法

遍历数组记录,只记录每次最大面积值。

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int[] nums = new int[n];
        for (int i = 0; i < n; i++) {
            nums[i] = sc.nextInt();
        }
        int maxS = 0;
        for (int i = 0; i < n; i++) {
            int s = 0;
            //  矩形的底
            int l = 1;
            int h = nums[i];
            for (int j = i; j < n; j++) {
                //  选取最矮的高
                h = Math.min(h, nums[j]);
                //  贪心
                s = Math.max(s, l * h);
                l++;
                //
                if (s >= maxS) maxS = s;
            }
        }
        System.out.println(maxS);
    }
}

 

这篇关于csp题集《最大的矩形》-Java的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!