【从零开始的LeetCode-算法】3200. 三角形的最大高度

给你两个整数 redblue,分别表示红色球和蓝色球的数量。你需要使用这些球来组成一个三角形,满足第 1 行有 1 个球,第 2 行有 2 个球,第 3 行有 3 个球,依此类推。

每一行的球必须是 相同 颜色,且相邻行的颜色必须不同

返回可以实现的三角形的 最大高度。

示例 1:

输入: red = 2, blue = 4

输出: 3

解释:

上图显示了唯一可能的排列方式。

示例 2:

输入: red = 2, blue = 1

输出: 2

解释:

上图显示了唯一可能的排列方式。

示例 3:

输入: red = 1, blue = 1

输出: 1

示例 4:

输入: red = 10, blue = 1

输出: 2

解释:

上图显示了唯一可能的排列方式。

提示:

  • 1 <= red, blue <= 100

我的解答:

java 复制代码
class Solution {
    public int maxHeightOfTriangle(int red, int blue) {
        int max_box = red >= blue ? red : blue; 
        int min_box = red >= blue ? blue : red; 
        // 作为奇数层,每多一层奇数层,总数应为 1 4 9 16  ... 规律为n^2 
        // 作为偶数层,每多一层哦数层,总数应为 2 6 12 20...规律为n(n + 1)
        
        // 尝试使用球数最少的颜色做计算,算出奇数层最高层数
        int min_odd_level  = (int)Math.floor(Math.sqrt(min_box));
        // 判断球数最多的颜色球数量是否要大于等于奇数层*(奇数层 + 1)。
        // 如果满足,则说明在最后的奇数层下方,还可加一层偶数层,此时偶数层比奇数层相同
        int max_even_level = max_box >= min_odd_level * (min_odd_level + 1) ? min_odd_level : min_odd_level - 1;
        
        // 判断作为偶数层时层数能否增加
        int min_even_level = min_box >= min_odd_level * (min_odd_level + 1) ? min_odd_level : 0;
        // 同理:判断球数最多的颜色球数量是否要大于等于(偶数层+1)^2。
        // 如果满足,则说明在最后的偶数层下方,还可加一层奇数层,此时偶数层比奇数层多一层
        int max_odd_level  = max_box >= (min_even_level + 1) * (min_even_level + 1) ? min_even_level + 1 : min_even_level;


        return  Math.max(min_odd_level + max_even_level,min_even_level + max_odd_level);
    }
}

优化:

移除使用sqrt()求根函数,避免内置函数使用的方法复杂且耗时【其实影响并不大,上述方法重复提交也有概率达到第一矩形上,跟网络有关】

java 复制代码
class Solution {
    public int maxHeightOfTriangle(int red, int blue) {
        int max_box = Math.max(red,blue);
        int min_box = Math.min(red,blue);
        // 作为奇数层,每多一层奇数层,总数应为 1 4 9 16 ... 规律为n^2
        // 作为偶数层,每多一层哦数层,总数应为 2 6 12 20...规律为n(n + 1)
        for (int i = 1;; i++) {
            // 如果不满足当前层的奇数层所需数量
            if(min_box < i * i) {
                // 判断是否满足上一层偶数层数量
                // 满足,说明球数最少的颜色小球放置在偶数行能使三角形高度最高
                // 反之,说明球数最少的颜色小球放置在奇数行能使三角形高度最高
                if (min_box >= (i - 1) * i) {
                    // 判断球数最多的颜色小球是否满足当前行所需奇数球数
                    return max_box >= i*i ? 2 * i - 1 : 2 * (i - 1);
                }else{
                    // 判断球数最多的颜色小球是否满足上一行所需偶数球数
                    return max_box >= i*(i - 1) ? 2 * (i - 1) : 2 * (i - 1) - 1;
                }
            }
            // 设为奇数层时,刚好全部放置完,此时是最优的结果
            if(min_box == i * i){
                // 判断球数最多的颜色小球是否满足当前行所需偶数球数
                return max_box >= i * (i + 1) ? 2*i : 2*i - 1;
            }
        }

    }
}
相关推荐
sky_smile_Allen几秒前
[C#] 关于数组的详细解释以及使用注意点
开发语言·算法·c#
Felix666yy2 分钟前
设计模式之建造者模式
java
界面开发小八哥3 分钟前
「Java EE开发指南」如何使用Visual JSF编辑器设计JSP?(一)
java·ide·java-ee·编辑器·myeclipse
先睡5 分钟前
javaEE
java·java-ee
程序猿小D13 分钟前
第三百三十一节 Java网络教程 - Java网络UDP多播
java·网络·udp
灭掉c与java16 分钟前
第五章springboot实现web的常用功能
java·spring boot·spring
希望有朝一日能如愿以偿18 分钟前
力扣题解(新增道路查询后的最短距离II)
算法
我感觉。27 分钟前
【机器学习chp6】对数几率回归
算法·机器学习·逻辑回归·分类模型·对数几率回归
初晴~27 分钟前
【Spring】RESTful设计风格
java·后端·spring·springboot·restful
风动也无爱1 小时前
Java的正则表达式和爬虫
java·爬虫·正则表达式