Java | Leetcode Java题解之第318题最大单词长度乘积

题目:

题解:

java 复制代码
class Solution {
    public int maxProduct(String[] words) {
        Map<Integer, Integer> map = new HashMap<Integer, Integer>();
        int length = words.length;
        for (int i = 0; i < length; i++) {
            int mask = 0;
            String word = words[i];
            int wordLength = word.length();
            for (int j = 0; j < wordLength; j++) {
                mask |= 1 << (word.charAt(j) - 'a');
            }
            if (wordLength > map.getOrDefault(mask, 0)) {
                map.put(mask, wordLength);
            }
        }
        int maxProd = 0;
        Set<Integer> maskSet = map.keySet();
        for (int mask1 : maskSet) {
            int wordLength1 = map.get(mask1);
            for (int mask2 : maskSet) {
                if ((mask1 & mask2) == 0) {
                    int wordLength2 = map.get(mask2);
                    maxProd = Math.max(maxProd, wordLength1 * wordLength2);
                }
            }
        }
        return maxProd;
    }
}
相关推荐
步步为营DotNet几秒前
深度解析C# 11 的Required成员:编译期验证逻辑与稳健编程实践
java·服务器·c#
沛沛老爹几秒前
2025年AI冲击下的Java Web开发现状
java·开发语言·人工智能·程序人生·职场和发展·年度总结
木辰風2 分钟前
EasyExcel根据动态字段,进行导出excel文件
java·前端·excel
q行2 分钟前
java学习日志--内部类
java·学习·内部类
资生算法程序员_畅想家_剑魔3 分钟前
Java常见技术分享-21-多线程安全-进阶模块-并发集合与线程池-ForkJoinPool
java·开发语言
a努力。4 分钟前
哈罗骑行Java面试被问:Redis的持久化策略对比
java·redis·面试
杰瑞不懂代码7 分钟前
结合os模块和shutil模块实现本地文件自动化操作
android·java·自动化·办公自动化·shutil·os
进阶的猿猴15 分钟前
easyExcel实现下拉单选框和(变相的下拉多选框)
java
Ccuno15 分钟前
Java 核心类库与数据结构
java·深度学习
辣机小司16 分钟前
【踩坑记录:EasyExcel 生产级实战:策略模式重构与防御性导入导出校验指南(实用工具类分享)】
java·spring boot·后端·重构·excel·策略模式·easyexcel