leetcode刷题_day10

本文介绍了一种在有序数组中查找唯一单元素的有效算法。通过分析两种不同的二分搜索实现方式,一种是调整中间索引的计算以确保其始终为奇数,另一种则利用位操作简化比较过程。最终,两种方法都能高效地找到目标元素。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

154.Single Element in a Sorted Array

1.本题我自己的写法受限于奇数和偶数坐标了,一开始尝试了mid的求法还是mid=l+(r-l)/2之后,mid有时为奇数有时为偶数,奇数得和前面对应,偶数得和后面对应,所以分出了挺多类,后来只能按mid为始终为奇数处理,然后采用了下面的mid = l+2*((r-l)/4)的解法。

class Solution {
public:
    int singleNonDuplicate(vector<int>& nums) {
        if(nums.size()==1)
            return nums[0];
        int l = 0,r = nums.size()-1,mid;
        while(r-l>=2)
        {   
            mid = l+2*((r-l)/4); 
            if(nums[mid]==nums[mid+1])
                l = mid+2;
            else 
                r = mid;
        }
        return nums[r];
    }
};
  1. 本题中答案的解法比较简单的一点是,采用c++异或运算,,然后mid为奇数mid1就是mid-1,mid为偶数,mid^1就是mid+1,省去了很多事,也算学到了。最后low和high返回值是一样的。
class Solution {
public:
    int singleNonDuplicate(vector<int>& nums) {
        int low = 0, high = nums.size() - 1;
        while (low < high) {
            int mid = (high - low) / 2 + low;
            if (nums[mid] == nums[mid ^ 1]) {
                low = mid + 1;
            } else {
                high = mid;
            }
        }
        return nums[low];
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值