贪心算法(9)(java)最优除法

题目:

给定一正整数数组 nums,nums中的相邻整数将进行浮点除法。例如,[2,3.4]->2/3/4.

例如,nums =[2,3,4],我们将求表达式的值"2/3/4"。

但是,你可以在任意位置添加任意数目的括号,来改变算数的优先级。你需要找出怎么添加括号,以便计算后的表达式的值为最大值。以字符串格式返回具有最大值的对应表达式。

注意:你的表达式不应该包含多余的括号。

输入:【1000,100,10,2】

输出:"1000/(100/10/2)"

解法一:(复杂,不推荐)

暴力解法->递归->记忆化搜索->动态规划

解法二:

贪心策略:除了前两个数以外,其余数全放在分子上即可。

java 复制代码
public class Solution {
    public String optimalDivision(int[]nums)
    {
        int n=nums.length;//获取数组长度
        StringBuffer ret=new StringBuffer();//拼接结果字符串
        if(n==1)//如果只有·一个元素,直接返回该元素
        {
            return ret.append(nums[0]).toString();

        }
        if(n==2)//如果有2个元素,返回a/b
        {
            return ret.append(nums[0]).append("/").append(nums[1]).toString();

        }
        //当元素个数大于2时,构造a/(b/c/d...)形式最大化结果
        ret.append(nums[0]).append("/(").append(nums[1]);
        for(int i=2;i<n;i++)//从第三个元素开始循环添加
        {
         ret.append("/").append(nums[i]);
        }
        ret.append(")");
        return ret.toString();


    }

    public static void main(String[] args) {
        Solution solution=new Solution();
        int[]nums={1000,100,10,2};
        System.out.println(solution.optimalDivision(nums));

    }
}
相关推荐
心之语歌40 分钟前
基于注解+拦截器的API动态路由实现方案
java·后端
华仔啊2 小时前
Stream 代码越写越难看?JDFrame 让 Java 逻辑回归优雅
java·后端
ray_liang2 小时前
用六边形架构与整洁架构对比是伪命题?
java·架构
AI软著研究员2 小时前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法
FunnySaltyFish2 小时前
什么?Compose 把 GapBuffer 换成了 LinkBuffer?
算法·kotlin·android jetpack
Ray Liang3 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
颜酱3 小时前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法
Java水解4 小时前
Java 中间件:Dubbo 服务降级(Mock 机制)
java·后端
SimonKing8 小时前
OpenCode AI辅助编程,不一样的编程思路,不写一行代码
java·后端·程序员
FastBean8 小时前
Jackson View Extension Spring Boot Starter
java·后端