704.二分查找
链接:704.二分查找
class Solution {
public:
int search(vector<int>& nums, int target) {
int left = 0;
int right = nums.size() - 1;
int mid = 0;
while(left <= right)
{
mid = (left + right) / 2;
if(nums[mid] == target) return mid;
else if(nums[mid] > target)
right = mid - 1;
else
left = mid + 1;
}
return -1;
}
};
参考资料
1.链接:代码随想录算法公开课-704.二分查找
思路与收获
1.因为之前写过二分查找,所以一气呵成写出来,顺利提交;
2.看了代码随想录算法公开课的讲解视频,熟悉了搜索区间分别为左闭右闭和左闭右开两种情况下的写法,我的代码中设置搜索区间为左闭右闭。
27.移除元素
链接:27.移除元素
class Solution {
public:
int removeElement(vector<int>& nums, int val) {
if(nums.size() == 0) return 0;
int* p1 = &nums[0];
int* p2 = &nums[0];
while(p2 <= &nums[0] + nums.size() - 1)
{
if(*p1 == val && *p2 == val)
{
p2++;
}
else if(*p1 == val && *p2 != val)
{
*p1 = *p2;
*p2 = val;
p1++;
p2++;
}
else if(*p1 != val && *p2 != val)
{
p1++;
p2++;
}
}
return p1 - &nums[0];
}
};
参考资料
1.力扣官方题解
思路与收获
1.想了很长时间,不过最后还是写出了双指针方案的代码,一次提交通过,完成之前觉得自己的算法已经很好了,完成之后看了力扣的官方题解,觉得还是有一些冗余的操作,与官方题解未优化的双指针方案差不多,不够完美。代码的时间复杂度为O(n)。
2.官方题解优化后的双指针方案左指针与右指针移动的次数加起来等于数组的长度,我的代码中p2指针移动的次数和p1指针移动的次数大于数组的长度。