leetcode_有序数组中的单一元素

540. 有序数组中的单一元素 - 力扣(LeetCode)

二分查找

使用条件 : 有序 , log n

复制代码
class Solution {
public:
    int singleNonDuplicate(vector<int>& nums) {
        int left = 0, right = nums.size() - 1, mid;
        while (left < right){
            mid = ( left + right ) / 2;
            if (mid % 2 == 1){
                mid -= 1;
            }
            if ( nums[mid] == nums[mid + 1] ){  //速说明这个数在右边
                left = mid + 2;
            }else {
                right = mid;
            }
        }
        return nums[left];
    }
};
相关推荐
苦藤新鸡6 小时前
6.三数之和
c语言·c++·算法·力扣
Frank_refuel6 小时前
C++之内存管理
java·数据结构·c++
s09071366 小时前
连通域标记:从原理到数学公式全解析
图像处理·算法·fpga开发·连通域标记
@小码农7 小时前
6547网:202512 GESP认证 C++编程 一级真题题库(附答案)
java·c++·算法
自然语7 小时前
人工智能之数字生命-特征类升级20260106
人工智能·算法
菜鸟233号7 小时前
力扣343 整数拆分 java实现
java·数据结构·算法·leetcode
赫凯7 小时前
【强化学习】第五章 时序差分算法
算法
leiming67 小时前
c++ find_if 算法
开发语言·c++·算法
yuanmenghao7 小时前
自动驾驶中间件iceoryx - 内存与 Chunk 管理(三)
数据结构·c++·算法·链表·中间件·自动驾驶
_OP_CHEN7 小时前
【算法基础篇】(四十三)数论之费马小定理深度解析:从同余性质到乘法逆元
c++·算法·蓝桥杯·数论·acm/icpc