当前位置: 首页 > article >正文

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

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

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

解法二: 

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

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));

    }
}


http://www.kler.cn/a/598589.html

相关文章:

  • 深入解析 Redis 实现分布式锁的最佳实践
  • 基于Spring Boot的二手物品交易管理系统的设计与实现(LW+源码+讲解)
  • 无人机动平衡-如何在螺旋桨上添加或移除材料
  • 2025年优化算法:龙卷风优化算法(Tornado optimizer with Coriolis force,TOC)
  • 常见中间件漏洞攻略-Jboss篇
  • 社群输出价值重构:AI技术驱动的持续内容生产体系研究
  • 蓝桥杯单片机刷题——串口发送显示
  • Java设计模式之备忘录模式
  • Linux 常用命令 - last 【显示历史登录用户列表】
  • 使用Docker运行 Ollama本地部署 DeepSeek 模型并用Dify实现可视化操作
  • Centos7搭建Zabbix4.x监控HCL模拟网络设备:zabbix-server搭建及监控基础03
  • 音视频学习(三十):fmp4
  • Shell正则表达式
  • fastapi+playwright爬取google搜索1-3页的关键词返回json
  • 《Solidity智能合约开发:从零到一实战指南》大纲
  • SpringBoot 第三课(Ⅰ) 数据层开发
  • Simple-BEV的bilinear_sample 作为view_transformer的解析,核心是3D-2D关联点生成
  • 8、undo log
  • 使用HAI来打通DeepSeek的任督二脉
  • 我的uniapp自定义模板