【从零开始的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;
            }
        }

    }
}
相关推荐
xqqxqxxq几秒前
Java 集合框架之线性表(List)实现技术笔记
java·笔记·python
L0CK9 分钟前
RESTful风格解析
java
程序员小假18 分钟前
我们来说说 ThreadLocal 的原理,使用场景及内存泄漏问题
java·后端
何中应20 分钟前
LinkedHashMap使用
java·后端·缓存
tryxr28 分钟前
Java 多线程标志位的使用
java·开发语言·volatile·内存可见性·标志位
talenteddriver33 分钟前
java: Java8以后hashmap扩容后根据高位确定元素新位置
java·算法·哈希算法
云泽80836 分钟前
STL容器性能探秘:stack、queue、deque的实现与CPU缓存命中率优化
java·c++·缓存
yyy(十一月限定版)42 分钟前
c语言——栈和队列
java·开发语言·数据结构
本地运行没问题1 小时前
基于Java注解、反射与动态代理:打造简易ORM框架
java
ss2731 小时前
Java线程池全解:工作原理、参数调优
java·linux·python