leetcode 540. Single Element in a Sorted Array

时间:2021-09-02 18:59:19

Given a sorted array consisting of only integers where every element appears twice except for one element which appears once. Find this single element that appears only once.

Example 1:
Input: [1,1,2,3,3,4,4,8,8]
Output: 2
Example 2:
Input: [3,3,7,7,10,11,11]
Output: 10
Note: Your solution should run in O(log n) time and O(1) space.

题目大意:一个有序的数列,有一个数出现一次,其他的数出现两次。求这个出现一次的数

思路:二分,首先序列是有序的,所以相邻的两个数要么相等,要么不相等。如果不相等,那会是哪个区间有single num呢 我们再判断区间(r-mid+1)是不是奇数
1.区间mid~r是奇数,并且nums[mid+1]和nums[mid]不等,说明single num出现在l~mid。
2.区间mid~r是偶数,并且nums[mid+1]和nums[mid]相等,说明single num出现在l~mid-1
3.区间mid~r是奇数,并且nums[mid+1]和nums[mid]相等,说明single num出现在mid~r
4.区间mid~r是偶数,并且nums[mid+1]和nums[mid]不等,single num出现在mid~r

代码如下:

class Solution {
public:

    int singleNonDuplicate(vector<int>& nums) {
        int l = 0;
        int r = nums.size()-1;
        int mid = 0;
        while (l < r) {
            mid = (l+r)/2;
            if (nums[mid+1] != nums[mid]) mid = mid+1;
            if ((r - mid + 1)%2) {
                l = mid;
            } else {
                r = mid - 1;
            }
        }
        return nums[r];
    }
};