【LeetCode】982. 按位与为零的三元组
创始人
2024-05-28 19:31:06
0

982. 按位与为零的三元组

题目描述

给你一个整数数组 nums ,返回其中 按位与三元组 的数目。

按位与三元组 是由下标 (i, j, k) 组成的三元组,并满足下述全部条件:

  • 0 <= i < nums.length
  • 0 <= j < nums.length
  • 0 <= k < nums.length
  • nums[i] & nums[j] & nums[k] == 0 ,其中 & 表示按位与运算符。

示例 1

输入:nums = [2,1,3]
输出:12
解释:可以选出如下 i, j, k 三元组:
(i=0, j=0, k=1) : 2 & 2 & 1
(i=0, j=1, k=0) : 2 & 1 & 2
(i=0, j=1, k=1) : 2 & 1 & 1
(i=0, j=1, k=2) : 2 & 1 & 3
(i=0, j=2, k=1) : 2 & 3 & 1
(i=1, j=0, k=0) : 1 & 2 & 2
(i=1, j=0, k=1) : 1 & 2 & 1
(i=1, j=0, k=2) : 1 & 2 & 3
(i=1, j=1, k=0) : 1 & 1 & 2
(i=1, j=2, k=0) : 1 & 3 & 2
(i=2, j=0, k=1) : 3 & 2 & 1
(i=2, j=1, k=0) : 3 & 1 & 2


示例 2

输入:nums = [0,0,0]
输出:27


提示

  • 1 <= nums.length <= 1000
  • 0 <= nums[i] < 216

算法一:哈希表 + 枚举

思路

  • 首先遍历 nums 的前两个值,因为题目中提到 0 <= nums[i] < 216 ,所以我们可以把这两个值按位与的结果存放到哈希表的索引哈希表的值为按位与结果的出现次数,这样的时间复杂度为 O(n2 + 216 * n) 。

收获

  • 我一开始的想法是:先计算前两个的值,存入数组中,然后再遍历数组的值与第三个 num ,但其实这样也是 三重循环,复杂度也是 O(n3) ,显然超时了;因此看了题解,复杂度可以降到 O(n2 + 216 * n)。

算法情况

  • 时间复杂度: O(n2 + 216 * n),其中 n 为 nums.size();

  • 空间复杂度:O(2 16);

    在这里插入图片描述

代码

class Solution {
public:int countTriplets(vector& nums) {int ans = 0;vector cnt(1<<16);for(int x : nums){for(int y : nums){cnt[x & y] ++;}}for(int n : nums){for(int i=0; i<(1<<16); ++i){if((i & n) == 0) ans += cnt[i];}}return ans;}
};

算法二:哈希表 + 枚举优化

思路

在这里插入图片描述在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

算法情况

  • 时间复杂度: O(n(n+U)),其中 n 为 nums 的长度,U=max⁡(nums);

  • 空间复杂度:O(U) 。

    在这里插入图片描述

代码

class Solution {
public:int countTriplets(vector& nums) {int ans = 0;int u=1;// 预先计算数组 cnt 的实际大小for(int n : nums){while(u <= n){u <<= 1;}} vector cnt(u);cnt[0] = nums.size();for(int n : nums){int m = (u-1) ^ n;for(int s=m; s; s=(s-1)&m){cnt[s]++;}}for(int x : nums){for(int y : nums){ans += cnt[x & y];}}return ans;}
};

参考资料

  1. 有技巧的枚举 + 常数优化(Python/Java/C++/Go)

相关内容

热门资讯

nova 4刷安卓系统,体验全... 最近手机界可是热闹非凡呢!听说华为nova 4要刷安卓系统了,这可真是让人兴奋不已。你有没有想过,你...
如果当初没有安卓系统,科技世界... 想象如果没有安卓系统,我们的生活会是怎样的呢?是不是觉得有点不可思议?别急,让我们一起穿越时空,探索...
安卓电视装win系统,系统转换... 亲爱的读者们,你是否曾想过,在你的安卓电视上装一个Windows系统,让它瞬间变身成为一台功能强大的...
安卓手机还原系统好处,重拾流畅... 你有没有遇到过安卓手机卡顿、运行缓慢的情况?别急,今天就来给你揭秘一下安卓手机还原系统的那些好处,让...
安卓系统能跑win吗,探索跨平... 你有没有想过,你的安卓手机里能不能装上Windows系统呢?这听起来是不是有点像科幻电影里的情节?别...
安卓车载系统蓝牙设置,畅享智能... 你有没有发现,现在开车的时候,手机和车载系统之间的互动越来越频繁了呢?这不,今天就来给你详细说说安卓...
奥利奥安卓系统,探索新一代智能... 你有没有想过,一块小小的奥利奥饼干竟然能和强大的安卓系统扯上关系?没错,今天就要来聊聊这个跨界组合,...
微信使用安卓系统,功能解析与操... 你有没有发现,现在用微信的人越来越多了呢?尤其是安卓系统的用户,简直就像潮水一样涌来。今天,就让我带...
体验最新原生安卓系统,极致体验... 你有没有想过,手机系统就像是我们生活的调味品,有时候换一种口味,生活都会变得有趣起来呢?最近,我体验...
安卓系统能玩原神,尽享奇幻冒险... 你有没有想过,在安卓系统上也能畅玩《原神》这样的热门游戏呢?没错,就是那个画面精美、角色丰富、玩法多...
安卓写手机银行系统,基于安卓平... 你有没有想过,手机银行系统在我们日常生活中扮演了多么重要的角色呢?每天刷刷手机,就能轻松管理账户,转...
僵尸之夜恐怖安卓系统,揭秘恐怖... 僵尸之夜,恐怖安卓系统来袭!想象一个寂静的夜晚,你正沉浸在美梦中,突然,一阵诡异的铃声打破了夜的宁静...
谷歌框架和安卓系统,构建智能移... 你有没有想过,为什么你的手机那么聪明,能帮你找到路线,还能帮你拍出美美的照片呢?这都要归功于一个超级...
安卓系统和oppo系统哪个流畅... 你有没有想过,手机系统哪个更流畅呢?安卓系统和OPPO系统,这两个名字听起来就让人心动。今天,咱们就...
安卓怎么用微软系统,利用微软系... 你是不是也和我一样,对安卓手机上的微软系统充满了好奇?想象那熟悉的Windows界面在你的安卓手机上...
安卓系统如何安装nfc,安卓系... 你有没有想过,用手机刷公交卡、支付账单,是不是比掏出钱包来得酷炫多了?这就得归功于NFC技术啦!今天...
ios系统可以转安卓,跨平台应... 你有没有想过,你的iPhone手机里的那些宝贝应用,能不能搬到安卓手机上继续使用呢?没错,今天就要来...
iOSapp移植到安卓系统,i... 你有没有想过,那些在iOS上让你爱不释手的app,是不是也能在安卓系统上大放异彩呢?今天,就让我带你...
现在安卓随便换系统,探索个性化... 你知道吗?现在安卓手机换系统简直就像换衣服一样简单!没错,就是那种随时随地、随心所欲的感觉。今天,就...
安卓系统安装按钮灰色,探究原因... 最近发现了一个让人头疼的小问题,那就是安卓手机的安装按钮突然变成了灰色,这可真是让人摸不着头脑。你知...