贪心算法(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));

    }
}
相关推荐
Vacant Seat3 分钟前
贪心算法-跳跃游戏II
算法·游戏·贪心算法
.生产的驴8 分钟前
SpringBoot 接口国际化i18n 多语言返回 中英文切换 全球化 语言切换
java·开发语言·spring boot·后端·前端框架
夜松云12 分钟前
从对数变换到深度框架:逻辑回归与交叉熵的数学原理及PyTorch实战
pytorch·算法·逻辑回归·梯度下降·交叉熵·对数变换·sigmoid函数
Howard_Stark12 分钟前
Spring的BeanFactory和FactoryBean的区别
java·后端·spring
饮长安千年月13 分钟前
学生管理系统审计
java·网络安全·代码审计
八股文领域大手子16 分钟前
深入浅出限流算法(三):追求极致精确的滑动日志
开发语言·数据结构·算法·leetcode·mybatis·哈希算法
-曾牛21 分钟前
Spring Boot中@RequestParam、@RequestBody、@PathVariable的区别与使用
java·spring boot·后端·intellij-idea·注解·spring boot 注解·混淆用法
新时代苦力工33 分钟前
处理对象集合,输出Map<String, Map<String, List<MyObject>>>格式数据,无序组合键处理方法
java·数据结构·list
啊阿狸不会拉杆40 分钟前
人工智能数学基础(一):人工智能与数学
人工智能·python·算法
一捌年1 小时前
java排序算法-计数排序
数据结构·算法·排序算法