算法奇妙屋(四十一)-贪心算法学习之路 8

文章目录

一. 力扣 134. 加油站

1. 题目解析

这里要求从i出发, 最后还要能回到i, 形成回路

2. 算法原理

这道题先写出暴力(枚举)解法, 然后在其基础上进行优化, 即可将时间复杂度降为O(N)

3. 代码

暴力解法(超时)

java 复制代码
class Solution {
    public int canCompleteCircuit(int[] gas, int[] cost) {
        int n = gas.length;
        int[] diff = new int[n];
        for (int i = 0; i < n; i++) {
            diff[i] = gas[i] - cost[i];
        }
        for (int i = 0; i < n; i++) {
            int profit = 0;
            int j = 0;
            for (; j <= n; j++) {
                profit += diff[(i + j) % n];
                if (profit < 0) {
                    break;
                }
            }
            if (profit >= 0) {
                return i;
            }
        }
        return -1;
    }
}

贪心优化

java 复制代码
class Solution {
    public int canCompleteCircuit(int[] gas, int[] cost) {
        int n = gas.length;
        int[] diff = new int[n];
        for (int i = 0; i < n; i++) {
            diff[i] = gas[i] - cost[i];
        }
        for (int i = 0; i < n; i++) {
            int profit = 0;
            int j = 0;
            for (; j <= n; j++) {
                profit += diff[(i + j) % n];
                if (profit < 0) {
                    break;
                }
            }
            if (profit >= 0) {
                return i;
            }
            i = i + j; // 优化
        }
        return -1;
    }
}

二. 力扣 738. 单调递增的数字

1. 题目解析

这道题的暴力解法很好想出来, 从当前数开始逐次递减, 直到每个位置都呈现递增即可

2. 算法原理

暴力解法是将数字变为字符串, 通过比较每个位置的字符即可, 这里图解只画出贪心解法

3. 代码

暴力解法代码(超时)

java 复制代码
class Solution {
    public int monotoneIncreasingDigits(int n) {
        while (n > 9) {
            StringBuilder s = new StringBuilder();
            s.append(n);
            int i = 1;
            for (; i < s.length(); i++) {
                if (s.charAt(i) < s.charAt(i - 1)) break;
            }
            if (i == s.length()) {
                return n;
            }
            n--;
        }
        return n;
    }
}

贪心解法代码

java 复制代码
class Solution {
    public int monotoneIncreasingDigits(int n) {
        StringBuilder s = new StringBuilder();
        s.append(n);
        int len = s.length();
        int i = 0;
        // 找最右面呈递减趋势的位置
        for (; i < len - 1; i++) {
            if (s.charAt(i) > s.charAt(i + 1)) break;
        }
        if (i == len - 1) {
            return n;
        }
        // 找最左边相同的数字位置
        char ch = s.charAt(i);
        int j = i;
        for (; j > 0; j--) {
            if (s.charAt(j - 1) != ch) break;
        }
        s.replace(j, j + 1, String.valueOf((char)(ch - 1)));
        // 该位置之后都变为9
        for (int k = j + 1; k < len; k++) {
            s.replace(k, k + 1, String.valueOf(9));
        }
        return Integer.valueOf(s.toString());
    }
}
相关推荐
渣渣苏6 小时前
硬核拆解 HNSW:亿级向量如何实现毫秒级召回?(上篇)
人工智能·算法·支持向量机·ai·向量数据库·hnsw·智能体
如竟没有火炬6 小时前
字符串相乘——int数组转字符串
开发语言·数据结构·python·算法·leetcode·深度优先
吃好睡好便好6 小时前
在Matlab中绘制三维等高线图
开发语言·python·学习·算法·matlab·信息可视化
项目申报小狂人6 小时前
一种使用双向长短时记忆网络结合鲸鱼优化算法的类火星矿物元素精确定量分析模型
人工智能·算法·lstm
wangjialelele6 小时前
【SystemV】基于建造者模式的信号量
linux·c语言·c++·算法·建造者模式
梅西库里RNG7 小时前
AI学习纪要——基础篇
人工智能·学习
朔北之忘 Clancy7 小时前
2026 年 3 月青少年软编等考 C 语言一级真题解析
c语言·开发语言·c++·学习·青少年编程·题解·一级
Aaron15887 小时前
RFSOC+VU13P/VU9P+GPU多通道同步一体化解决方案
人工智能·嵌入式硬件·算法·matlab·fpga开发·硬件架构·基带工程
张二娃同学7 小时前
第12篇_深度学习学习路线总结
人工智能·python·深度学习·神经网络·学习
淡海水8 小时前
ComfyUI全面掌握-知识点详解——基础示例:文生图与图生图实操(参数+案例)
大数据·人工智能·算法·comfyui