2024.3.20力扣每日一题——数组元素的最小非零乘积

题目来源

力扣每日一题;题序:1969

我的题解

方法一 贪心

采用贪心,使得最终的序列应该是满足除了二进制位全为1的 2 p − 1 2^p-1 2p1之外,其余的首尾两两配对进行交换,最终使得半数为1,半数为 2 p − 1 2^{p-1} 2p1.

时间复杂度:O(n)
空间复杂度:O(1)

public int minNonZeroProduct(int p) {
    if (p == 1) {
        return 1;
    }
    long mod = 1000000007;
    long x=fastPow(2,p,mod)-1;
    long y = (long) 1 << (p - 1);
    long t=fastPow(x-1,y-1,mod);
    t=t*x%mod;
    return (int)t;
}
public long fastPow(long x, long n, long mod) {
    long res = 1;
    for (; n != 0; n >>= 1) {
        if ((n & 1) != 0) {
            res = res * x % mod;
        }
        x = x * x % mod;
    }
    return res;
}

有任何问题,欢迎评论区交流,欢迎评论区提供其它解题思路(代码),也可以点个赞支持一下作者哈😄~

相关推荐

最近更新

  1. TCP协议是安全的吗?

    2024-04-06 06:32:06       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-06 06:32:06       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-06 06:32:06       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-06 06:32:06       18 阅读

热门阅读

  1. 【云计算】云网络是未来的网络基础设施

    2024-04-06 06:32:06       15 阅读
  2. Ubuntu系统安装NVIDIA 与pytorch

    2024-04-06 06:32:06       13 阅读
  3. pytorch中的nn.MSELoss()均方误差损失函数

    2024-04-06 06:32:06       14 阅读
  4. Django -- 自动化测试

    2024-04-06 06:32:06       11 阅读
  5. Linux 中 .bashrc、.bash-profile 和 .profile 之间的区别

    2024-04-06 06:32:06       9 阅读
  6. 解决安卓手机系统文件夹看不到的问题

    2024-04-06 06:32:06       14 阅读
  7. 稀碎从零算法笔记Day40-LeetCode:加油站

    2024-04-06 06:32:06       14 阅读
  8. 0基础如何进入IT行业?

    2024-04-06 06:32:06       13 阅读
  9. AI赋能写作:探索设计模式的魅力

    2024-04-06 06:32:06       13 阅读
  10. 位运算 -力扣90. 颠倒二进制位

    2024-04-06 06:32:06       10 阅读