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];
    }
};
相关推荐
2401_857918292 分钟前
C++与自动驾驶系统
开发语言·c++·算法
乐分启航6 分钟前
【无标题】
深度学习·算法·目标检测·transformer·迁移学习
GfovikS0610013 分钟前
C++中的函数式编程
开发语言·c++·算法
2401_8579182914 分钟前
C++中的构建器模式
开发语言·c++·算法
穿条秋裤到处跑18 分钟前
每日一道leetcode(2026.03.25):等和矩阵分割 I
算法·leetcode·矩阵
实心儿儿26 分钟前
算法9:相同的树
算法·leetcode·职场和发展
another heaven29 分钟前
【计算机 字符编码类型及其应用场景详解】
数据结构·字符编码
Zarek枫煜32 分钟前
zig与c3的算法 -- 静态队列
开发语言·stm32·单片机·嵌入式硬件·算法·51单片机
fff98111833 分钟前
基于C++的爬虫框架
开发语言·c++·算法
XiYang-DING36 分钟前
【LeetCode】Easy | 387. 字符串中的第一个唯一字符
算法·leetcode·职场和发展