码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • LeetCode 318. 最大单词长度乘积


    给你一个字符串数组 words ,找出并返回 length(words[i]) * length(words[j]) 的最大值,并且这两个单词不含有公共字母。如果不存在这样的两个单词,返回 0 。

    示例 1:

    输入:words = ["abcw","baz","foo","bar","xtfn","abcdef"]
    输出:
    1. 16
    2. 解释
    :这两个单词为 "abcw", "xtfn"。

    示例 2:

    输入:words = ["a","ab","abc","d","cd","bcd","abcd"]
    输出:
    1. 4
    2. 解释
    :这两个单词为 "ab", "cd"。

    示例 3:

    输入:words = ["a","aa","aaa","aaaa"]
    输出:
    1. 0
    2. 解释
    :不存在这样的两个单词。

    提示:

    • 2 <= words.length <= 1000
    • 1 <= words[i].length <= 1000
    • words[i] 仅包含小写字母
    1. class Solution {
    2. public int maxProduct(String[] words) {
    3. int[] wordArr = new int[words.length];
    4. for (int i = 0; i < words.length; i++) {
    5. for (char ch : words[i].toCharArray()) {
    6. wordArr[i] |= 1 << (ch - 'a');
    7. }
    8. }
    9. int res = 0;
    10. for (int i = 0; i < wordArr.length; i++) {
    11. for (int j = i + 1; j < wordArr.length; j++) {
    12. if ((wordArr[i] & wordArr[j]) == 0) {
    13. res = Math.max(res, words[i].length() * words[j].length());
    14. }
    15. }
    16. }
    17. return res;
    18. }
    19. }

    位运算解释(来自chat-gpt):

    1. |= 是一个按位或赋值运算符。它执行当前wordArr[i]值与右侧值的按位或操作,然后将结果赋回给wordArr[i]。在这种情况下,它用于设置wordArr[i]中的特定位。

    2. 1 << (ch - 'a') 是一个位操作。它的工作方式如下:

      • ch 是一个字符。
      • ch 与字符 'a' 的ASCII值相减,得到ch与 'a' 的ASCII值之间的差值。这本质上将每个字符映射到字母表中的一个位置。例如,如果ch是 'a',则该表达式的值为0,如果ch是 'b',则值为1,依此类推。
      • 然后,将1左移前面步骤得到的值的位数。这意味着将1的二进制表示向左移动这么多位。将1左移0位不会改变它(1 << 0 = 1),将1左移1位得到2(1 << 1 = 2),将1左移2位得到4(1 << 2 = 4),依此类推。
  • 相关阅读:
    企业如何实现安全可靠的云密码管理
    【递归、搜索与回溯算法】第三节.21. 合并两个有序链表和206. 反转链表和24. 两两交换链表中的节点
    Python编程指南:利用HTTP和HTTPS适配器实现智能路由
    机器学习_特征工程_特征数据的评价标准
    ffmpeg 查看本地摄像头和麦克风设备名称
    设计模式之状态模式
    通讯录和内存动态管理
    react-组件间的通讯
    深度强化学习与APS的一些感想
    mask-R-CNN
  • 原文地址:https://blog.csdn.net/weixin_39383751/article/details/134256635
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号