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;
    }
}
相关推荐
redemption_215 分钟前
SpringMVC-03-HelloSpring
java
平头哥在等你31 分钟前
C语言简答题答案
java·c语言·jvm
LKID体36 分钟前
【python图解】数据结构之字典和集合
java·服务器·前端
HUT_Tyne2651 小时前
力扣--LCR 154.复杂链表的复制
java·leetcode·链表
黄昏_1 小时前
在Springboot项目中实现将文件上传至阿里云 OSS
java·spring boot·后端·阿里云
期待未来的男孩1 小时前
安全加固方案
java·网络·安全
惜.己1 小时前
Jmeter中的配置原件
java·前端·数据库
zhuzhihongNO12 小时前
JVM(JAVA虚拟机)内存溢出导致内存不足,Java运行时环境无法继续
java·开发语言·jvm·内存溢出·jvm内存溢出
MaxCosmos20012 小时前
读《Effective Java》笔记 - 条目7
java·jvm·笔记
学点东西吧.2 小时前
JVM(六、Java内存分配)
java·开发语言·jvm