Leetcode2568. 最小无法得到的或值

给定一个整数数组nums,返回数组中无法通过任何子序列的按位或运算得到的最小非零整数。例如,对于数组[2,1],由于2|1=3,3是可表达的,而4不可表达,所以返回4。解题方法是检查2的幂次是否都在nums中,若不在则该幂次即为答案。
摘要由CSDN通过智能技术生成

题目链接

Leetcode2568. 最小无法得到的或值 Rating : 1754

题目描述

给你一个下标从 0 开始的整数数组 nums

如果存在一些整数满足 0 <= index1 < index2 < ... < indexk < nums.length````,得到 nums[index1] | nums[index2] | … | nums[indexk] = x,那么我们说 x是 可表达的 。换言之,如果一个整数能由 nums```的某个子序列的或运算得到,那么它就是可表达的。

请你返回 nums不可表达的 最小非零整数

示例 1:

输入:nums = [2,1]
输出:4
解释:1 和 2 已经在数组中,因为 nums[0] | nums[1] = 2 | 1 = 3 ,所以 3 是可表达的。由于 4 是不可表达的,所以我们返回 4 。

示例 2:

输入:nums = [5,3,2]
输出:1
解释:1 是最小不可表达的数字。

提示:
  • 1 < = n u m s . l e n g t h < = 1 0 5 1 <= nums.length <= 10^5 1<=nums.length<=105
  • 1 < = n u m s [ i ] < = 1 0 9 1 <= nums[i] <= 10^9 1<=nums[i]<=109

解法:脑筋急转弯

  • 1 可以表示 1
  • 1 , 2 可以表示 1 , 2 , 3
  • 1 , 2 , 4 可以表示 1 , 2 , 3 , 4 , 5 , 6 , 7

所以我们只需要判断 2的幂次 是否在nums中即可。

如果 2 k 2^k 2k k k k从0开始增加)不在 nums中,即答案就是 2 k 2^k 2k

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

C++代码:

class Solution {
public:
    int minImpossibleOR(vector<int>& nums) {
       unordered_set s(nums.begin(), nums.end());
        for (int i = 1;; i <<= 1)
            if (!s.count(i))
                return i;
    }
};

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值