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;
    }
}
相关推荐
曼巴UE56 分钟前
UE C++ 字符串的操作
java·开发语言·c++
鹿角片ljp11 分钟前
力扣104.求二叉树最大深度:递归和迭代
算法·leetcode·二叉树·递归
凛_Lin~~13 分钟前
安卓/Java语言基础八股文
java·开发语言·安卓
老华带你飞14 分钟前
出行旅游安排|基于springboot出行旅游安排系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·spring·旅游
nvvas27 分钟前
Java AI开发入门指南
java·人工智能
元亓亓亓28 分钟前
考研408--操作系统--day8--操作系统--虚拟内存&请求分页&页面置换/分配
android·java·开发语言·虚拟内存
CoderYanger40 分钟前
贪心算法:6.递增的三元子序列
java·算法·leetcode·贪心算法·1024程序员节
一条大祥脚43 分钟前
Cuda Rudece算子实现(附4090/h100测试)
java·数据结构·算法
嗑瓜子儿溜茶水儿1 小时前
docker 部署 kkfileview ; arm64; ky10;
java·docker
CoderYanger1 小时前
贪心算法:1.柠檬水找零
java·算法·leetcode·贪心算法·1024程序员节