​LeetCode刷题实战553:最优除法

算法的重要性,我就不多说了吧,想去大厂,就必须要经过基础知识和业务逻辑面试+算法面试。所以,为了提高大家的算法能力,这个公众号后续每天带大家做一道算法题,题目就从LeetCode上面选 !

今天和大家聊的问题叫做 最优除法,我们先来看题面:
https://leetcode-cn.com/problems/optimal-division/

You are given an integer array nums. The adjacent integers in nums will perform the float division.


For example, for nums = [2,3,4], we will evaluate the expression “2/3/4”.

However, you can add any number of parenthesis at any position to change the priority of operations. You want to add these parentheses such the value of the expression after the evaluation is maximum.


Return the corresponding expression that has the maximum value in string format.


Note: your expression should not contain redundant parenthesis.


给定一组正整数,相邻的整数之间将会进行浮点除法操作。例如, [2,3,4] -> 2 / 3 / 4 。
但是,你可以在任意位置添加任意数目的括号,来改变算数的优先级。你需要找出怎么添加括号,才能得到最大的结果,并且返回相应的字符串格式的表达式。你的表达式不应该含有冗余的括号。

示例                         

输入: [1000,100,10,2]
输出: "1000/(100/10/2)"
解释:
1000/(100/10/2) = 1000/((100/10)/2) = 200
但是,以下加粗的括号 "1000/((100/10)/2)" 是冗余的,
因为他们并不影响操作的优先级,所以你需要返回 "1000/(100/10/2)"

其他用例:
1000/(100/10)/2 = 50
1000/(100/(10/2)) = 50
1000/100/10/2 = 0.5
1000/100/(10/2) = 2


解题


对于这种题目我们可以先找一下其中的规律,可以发现t = a1 / a2 / a3 … / an,要想使得结果最大那么我们在加括号的时候需要尽可能使得越多的数字由除法变成乘法,例如:a1/ a2 / a3 = a1 / (a2 / a3) = a1 / a2 * a3,可以发现a2无论如何也无法变成乘法的,所以我们只需要在a2与an外面加上括号即可使得a2后面的数字都变成乘法,这样的结果肯定是最大的,我们需要在一开始特判一下nums中0,1,2个数字的情况即可。

class Solution {
    public String optimalDivision(int[] nums) {
        int n = nums.length;
        if (n == 1) {
            return String.valueOf(nums[0]);
        }
        if (n == 2) {
            return String.valueOf(nums[0]) + "/" + String.valueOf(nums[1]);
        }
        StringBuffer res = new StringBuffer();
        res.append(nums[0]);
        res.append("/(");
        res.append(nums[1]);
        for (int i = 2; i < n; i++) {
            res.append("/");
            res.append(nums[i]);
        }
        res.append(")");
        return res.toString();
    }
}


好了,今天的文章就到这里,如果觉得有所收获,请顺手点个在看或者转发吧,你们的支持是我最大的动力 。

上期推文:

LeetCode1-540题汇总,希望对你有点帮助!
LeetCode刷题实战541:反转字符串 II
LeetCode刷题实战542:01 矩阵
LeetCode刷题实战543:二叉树的直径
LeetCode刷题实战544:输出比赛匹配对
LeetCode刷题实战545:二叉树的边界
LeetCode刷题实战546:移除盒子
LeetCode刷题实战547:省份数量
LeetCode刷题实战548:将数组分割成和相等的子数组
LeetCode刷题实战549:二叉树中最长的连续序列
LeetCode刷题实战550:游戏玩法分析 IV
LeetCode刷题实战551:学生出勤记录 I
LeetCode刷题实战552:学生出勤记录 II

​LeetCode刷题实战553:最优除法

本篇文章来源于微信公众号:程序IT圈

原创文章,作者:栈长,如若转载,请注明出处:https://www.cxyquan.com/20651.html

发表评论

登录后才能评论

联系我们

400-800-8888

在线咨询:点击这里给我发消息

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息