给你一个仅由整数组成的有序数组,其中每个元素都会出现两次,唯有一个数只会出现一次。
请你找出并返回只出现一次的那个数。
你设计的解决方案必须满足 O(log n) 时间复杂度和 O(1) 空间复杂度。
示例 1:
输入: nums = [1,1,2,3,3,4,4,8,8]
输出: 2
示例 2:
输入: nums = [3,3,7,7,10,11,11]
输出: 10
提示:
- 1 <= nums.length <= 10^5
- 0 <= nums[i] <= 10^5
分析:
方法:二分法
题目要求时间复杂度 O(log n),很明显就是让我们用二分法来解题。因为数组是升序排序且除了某数都是成对存在的(今天情人节我怀疑这道题在暗示什么),所以成对的数都是挨在一起的,因此我们只需要判断在奇偶二分点下,旁边的数是否和自己一样,就能确定单身数在那个范围内。
奇数点(指索引):
- 1 1 2 2 3 3 4 和右边不一样,单身数在右边
- 1 2 2 3 3 4 4 和右边一样,单身数在左边
偶数点:
- 1 1 2 3