码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • [leetcode 数位运算] 2939. 最大异或乘积 M


    给你三个整数 a ,b 和 n ,请你返回 (a XOR x) * (b XOR x) 的 最大值 且 x 需要满足 0 <= x < 2n。

    由于答案可能会很大,返回它对 109 + 7 取余 后的结果。

    注意,XOR 是按位异或操作。

    示例 1:

    输入:a = 12, b = 5, n = 4
    输出:98
    解释:当 x = 2 时,(a XOR x) = 14 且 (b XOR x) = 7 。所以,(a XOR x) * (b XOR x) = 98 。
    98 是所有满足 0 <= x < 2n 中 (a XOR x) * (b XOR x) 的最大值。
    示例 2:

    输入:a = 6, b = 7 , n = 5
    输出:930
    解释:当 x = 25 时,(a XOR x) = 31 且 (b XOR x) = 30 。所以,(a XOR x) * (b XOR x) = 930 。
    930 是所有满足 0 <= x < 2n 中 (a XOR x) * (b XOR x) 的最大值。
    示例 3:

    输入:a = 1, b = 6, n = 3
    输出:12
    解释: 当 x = 5 时,(a XOR x) = 4 且 (b XOR x) = 3 。所以,(a XOR x) * (b XOR x) = 12 。
    12 是所有满足 0 <= x < 2n 中 (a XOR x) * (b XOR x) 的最大值。

    提示:

    0 <= a, b < 250
    0 <= n <= 50

    class Solution {
        public int maximumXorProduct(long a, long b, int n) {
            if(a < b) {
                a = a ^ b;
                b = a ^ b;
                a = a ^ b;
            }
            long MOD = (int)1e9+7;
            long mask = (1L<<n)-1; // n个1
            long ax = a & ~mask; // 没办法通过 xor x 修改的部分
            long bx = b & ~mask;
    
            a &= mask; // 保留低于n的比特位
            b &= mask;
            long left = a ^ b; // 一个是0 一个是1 的比特位
            long one = mask ^ left; // 全为 1 或者 全为0 的比特位
            ax |= one; // 异或结果一定是1先加到结果
            bx |= one;
            if(left > 0 && ax == bx) {
                // left 的最高位给ax 其余给bx
                long high_bit = 1L << (63 - Long.numberOfLeadingZeros(left));
                ax |= high_bit;
                left ^= high_bit;
            }
            bx |= left;
            return (int) (ax % MOD * (bx % MOD) % MOD);
    
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
  • 相关阅读:
    MySQL8.0 一主二从
    IntelliJ IDEA 2022.2 正式来临:已完全支持 Spring 6 和 Spring Boot 3
    JVM(Java Virtual Machine)内存模型篇
    JavaFX开发教程——前后端交互(Controller)
    java计算机毕业设计游泳馆信息管理系统源程序+mysql+系统+lw文档+远程调试
    央国企信创改造难在何处?先行建设国产身份域管可少走弯路
    笔记--autosar是什么
    C语言实现扫雷游戏
    【SSM框架】Mybatis详解06 对象分析、注册别名、设置日志输出
    C++输入输出流2
  • 原文地址:https://blog.csdn.net/qq_45704048/article/details/134564723
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号