位运算-201. 数字范围按位与,137. 只出现一次的数字 II(总结此类)

给你两个整数 left 和 right ,表示区间 [left, right] ,返回此区间内所有数字 按位与 的结果(包含 left 、right 端点)。

示例 1:

输入:left = 5, right = 7 输出:4 示例 2:

输入:left = 0, right = 0 输出:0 示例 3:

输入:left = 1, right = 2147483647 输出:0

java 复制代码
class Solution {
    public int rangeBitwiseAnd(int left, int right) {
            int index=0;
            for(int i=0;i<32;i++){
                if((left==right))
                       break;
                left >>=1;
                right>>=1;
                index++;
            }
            return left <<=index;

    }
}
  1. 只出现一次的数字 II 已解答 中等 相关标签 相关企业 给你一个整数数组 nums ,除某个元素仅出现 一次 外,其余每个元素都恰出现 三次 。请你找出并返回那个只出现了一次的元素。

你必须设计并实现线性时间复杂度的算法且使用常数级空间来解决此问题。

示例 1:

输入:nums = [2,2,3,2] 输出:3

示例 2:

输入:nums = [0,1,0,1,0,1,99] 输出:99

java 复制代码
class Solution {
    public int singleNumber(int[] nums) {
       int[] arr=new int[32];
       for(int num:nums){
       for(int i=0;i<32;i++){
             arr[31-i] +=num &1;
             num >>=1;
       }
       }
       int end =0;
       for(int j=0;j<32;j++){
           arr[31-j] %=3;
          end |= arr[31-j]<<j;
         
       }
        return end;
    }
}
  1. 只出现一次的数字
    已解答
    简单
    相关标签
    相关企业
    给你一个 非空 整数数组 nums ,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。

你必须设计并实现线性时间复杂度的算法来解决此问题,且该算法只使用常量额外空间。

示例 1 :

输入:nums = [2,2,1]

输出:1

示例 2 :

输入:nums = [4,1,2,1,2]

输出:4

示例 3 :

输入:nums = [1]

输出:1

java 复制代码
class Solution {
    public int singleNumber(int[] nums) {
        int[] arr=new int[32];
        for(int num: nums){
            for(int i=0;i<32;i++){
                arr[31-i] +=num &1;
                num >>=1;
            }
        }
        int end =0;
        for(int j=0;j<32;j++){
            arr[31-j] %= 2;
           end |= arr[31-j] <<j;
        }
            return end;
    }
}
相关推荐
ankleless12 小时前
C语言(11)—— 数组(超绝详细总结)
c语言·零基础·数组·二维数组·自学·一维数组
梁辰兴2 天前
数据结构:串、数组与广义表
开发语言·数据结构·c··数组·广义表
Q741_1476 天前
如何判断一个数是 2 的幂 / 3 的幂 / 4 的幂 / n 的幂 位运算 总结和思考 每日一题 C++的题解与思路
开发语言·c++·算法·leetcode·位运算·总结思考
没有bug.的程序员6 天前
《常见高频算法题 Java 解法实战精讲(1):链表与数组》
java·算法·链表·数组
码破苍穹ovo8 天前
堆----3.数据流的中位数
java·数据结构·算法·力扣
崎岖Qiu8 天前
leetcode1343:大小为K的子数组(定长滑动窗口)
java·算法·leetcode·力扣·滑动窗口
崎岖Qiu10 天前
leetcode643:子数组最大平均数 I(滑动窗口入门之定长滑动窗口)
java·算法·leetcode·力扣·双指针·滑动窗口
CUC-MenG12 天前
2025牛客多校第五场 K.完美旅程 J.最快覆盖问题 E.神秘异或操作 个人题解
数学·dfs·bfs·优先队列·二分·位运算·fmt·曼哈顿距离·fwt
Tisfy15 天前
LeetCode 2411.按位或最大的最小子数组长度:一次倒序遍历
数据结构·算法·leetcode·题解·位运算·遍历
意法半导体STM3217 天前
STM32CubeMX 生成时钟获取函数的分析
mcu·stm32cubemx·数组·st·意法半导体·hal 时钟获取函数