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

文章目录

一. 力扣 409. 最长回文串

1. 题目解析

给定的字符串s, 使用s中的字符, 来构建最长的回文串, 这里字符不必全部使用

2. 算法原理

这里有两个小技巧👇
1. 这里我们可以使用当前字符个数m / 2 后再✖️2, 这样无论m奇偶, 可以得到偶数的长度
2. 用最后ret长度与原长度比较, 来判断是否有奇数字符

3. 代码

使用哈希表

java 复制代码
class Solution {
    public int longestPalindrome(String s) {
        HashMap<Character, Integer> hash = new HashMap<>();
        int n = s.length(), ret = 0;
        for (int i = 0; i < n; i++) {
            char ch = s.charAt(i);
            hash.put(ch, hash.getOrDefault(ch, 0) + 1);
        }
        for (Map.Entry<Character, Integer> entry : hash.entrySet()) {
            ret += entry.getValue() / 2 * 2;
        }
        return ret == n ? ret : ret + 1;
    }
}

使用数组模拟哈希表, 效率更高, 且空间利用率更低

java 复制代码
class Solution {
    public int longestPalindrome(String s) {
        int[] hash = new int[127];
        int n = s.length(), ret = 0;
        for (int i = 0; i < n; i++) {
            hash[s.charAt(i)]++;
        }
        for (int x : hash) {
            ret += x / 2 * 2;
        }
        return ret == n ? ret : ret + 1;
    }
}

二. 力扣 942. 增减字符串匹配

1. 题目解析

这道题理解题意很重要, 要注意是0到n, 总共n+1个数

2. 算法原理

升序时, 当前位置选最小值, 那么后一个位置不论选什么必定都大于该值
降序时, 当前位置选最大值, 那么后一个位置不论选什么必定都小于该值

相关推荐
鱼鳞_3 分钟前
苍穹外卖-Day10(Spring task)
java·后端·spring
雨落在了我的手上11 分钟前
初始java(十七):常⽤⼯具类介绍
java·开发语言
手写码匠18 分钟前
华为云Flexus+DeepSeek征文|基于华为云Flexus X实例 + Dify + DeepSeek 构建企业级智能知识库问答系统实战
人工智能·深度学习·算法·aigc
凤凰院凶涛QAQ22 分钟前
《Java版数据结构 & 集合类剖析》集合框架的封装设计与顺序表:“从 Iterable 到 ArrayList:集合框架的‘职业树“
java·开发语言·数据结构
吴可可12334 分钟前
Win7上开发CAD2004自定义实体全解析
c++·算法
孟华苏36 分钟前
怎么快速排查内存泄漏问题
java·开发语言·python
YXXY31336 分钟前
二叉树中的深搜算法介绍
算法
zz345729811338 分钟前
C语言中字符串常量存储位置
c语言·开发语言·算法·青少年编程
noipp39 分钟前
推荐题目:洛谷 P16510 [GKS 2015 #C] gRanks
java·c语言·开发语言·c++·python·算法
flyinmind39 分钟前
Java环境与Android环境中使用QuickJS
java·开发语言·javascript·quickjs