算法奇妙屋(三十九)-贪心算法学习之路 6

文章目录

一. 力扣 455. 分发饼干

1. 题目解析

饼干s[j] >= 胃口g[i]时, ret++, 求最后ret的最大值

2. 算法原理

3. 代码

java 复制代码
class Solution {
    public int findContentChildren(int[] g, int[] s) {
        Arrays.sort(g);
        Arrays.sort(s);
        int i = 0, j = 0, m = g.length, n = s.length, ret = 0;
        while (i < m && j < n) {
            if (s[j] >= g[i]) {
                j++;
                i++;
                ret++;
            }else {
                j++;
            }
        }
        return ret;
    }
}

二. 力扣 553. 最优除法

1. 题目解析

让我们任意添加括号, 来求最大值


2. 算法原理

题目中nums[i] >= 2, 很关键, 意味着我们可以使用分子最大值的情况, 任意两个数相乘绝对大于原值

3. 代码

java 复制代码
class Solution {
    public String optimalDivision(int[] nums) {
        int n = nums.length;
        StringBuilder ret = new StringBuilder();
        ret.append(nums[0]);
        if (n == 1) {
            return ret.toString();
        }else if (n == 2) {
            ret.append("/");
            ret.append(nums[1]);
            return ret.toString();
        }
        for (int i = 1; i < n; i++) {
            ret.append("/");
            if (i == 1) {
                ret.append("(");
            }
            ret.append(nums[i]);
            if (i == n - 1) {
                ret.append(")");
            }
        }
        return ret.toString();
    }
}
相关推荐
AlunYegeer2 小时前
黑马头条踩坑总结:频道状态筛选前端联调失效问题
java·前端
bu_shuo2 小时前
git学习
git·学习
糖炒栗子03262 小时前
后端消息投递可靠性:基于 RabbitMQ 的“双重防线-幂等闭环”模式
java·后端·rabbitmq
不像程序员的程序媛2 小时前
es查询是否存在某个字段
java·前端·elasticsearch
无籽西瓜a2 小时前
【西瓜带你学设计模式 | 第九期 - 代理模式】代理模式 —— 静态与动态代理实现、优缺点与适用场景
java·后端·设计模式·软件工程·代理模式
两年半的个人练习生^_^2 小时前
ThreadLocal的使用和源码
java·开发语言
编程之升级打怪2 小时前
有难度的关键算法
算法
SarL EMEN2 小时前
Spring boot创建时常用的依赖
java·spring boot·后端