当前位置: 首页 > news >正文

宁波高端网站建设怀化网络推广

宁波高端网站建设,怀化网络推广,给公司做兼职维护网站多少钱,网站设计目的与规划怎么写代码随想录二刷day01704. 二分查找27. 移除元素977. 有序数组的平方704. 二分查找 题目链接 做这种题最好现在纸上写一写,如果在大脑中想,可能一会就晕了。 二刷的时候发现了一个新的知识点 即: >>的作用 二分法第二种写法&#xff1a…

代码随想录二刷day01

      • 704. 二分查找
      • 27. 移除元素
      • 977. 有序数组的平方

704. 二分查找

题目链接
做这种题最好现在纸上写一写,如果在大脑中想,可能一会就晕了。 二刷的时候发现了一个新的知识点 即: >>的作用
二分法第二种写法:左闭右开[left, right)

  • left <=right 时没有意义
  • if (nums[middle] > target) right 要赋值为 middle ,因为当前这个nums[middle]一定不是target
  • if (nums[middle] < target) left 要赋值为 middle ,因为当前这个nums[middle]一定不是target
class Solution {
public:int search(vector<int>& nums, int target) {int left = 0;int right = nums.size(); // 定义target在左闭右开的区间里,即:[left, right)while (left < right) { // 因为left == right的时候,在[left, right)是无效的空间,所以使用 <int middle = left + ((right - left) >> 1);if (nums[middle] > target) {right = middle; // target 在左区间,在[left, middle)中} else if (nums[middle] < target) {left = middle + 1; // target 在右区间,在[middle + 1, right)中} else { // nums[middle] == targetreturn middle; // 数组中找到目标值,直接返回下标}}// 未找到目标值return -1;}
};

int middle = left + ((right - left) >> 1) 相当于 int middle = left + ((right - left) / 2)
举个小栗子

>>: 二进制右移
举个例子: 1010 >> 1 == 0101
1010 十进制 10
0101 十进制 5
综上 >> 1 作用相当于除二

所以 left + ((right -left) >> 1) ==> left + ((right -left)/2)

为什么不直接用(left + right) /2 而用left + ((right -left) >> 1)
答: 是因为left + right 在某种情况下可能会超过基本类型所能容纳的最大值,而且 >> (位运算) 比 / 运算要快一点。

27. 移除元素

题目链接
解题思路: 双指针(快慢指针法) 一快一慢。

本题中:

  • 快指针 是用来获取新数组中的元素;
  • 慢指针是用来获取新数组中需要更新的位置。
// 时间复杂度:O(n)
// 空间复杂度:O(1)
class Solution {
public:int removeElement(vector<int>& nums, int val) {int slowIndex = 0;for(int fastIndex = 0; fastIndex < nums.size();fastIndex++){if(val != nums[fastIndex]){nums[slowIndex++] = nums[fastIndex];}}return slowIndex;}
};

注:数组的元素在内存地址中是连续的,不能单独删除数组中的某个元素,只能覆盖。


977. 有序数组的平方

题目链接
注:本题中给出的数组是有序的,则最大值应该在两端,不可能在中间。
采用双指针,从两边向中间就行遍历,并比较大小,将大的放在右端。
i 指向 起始位置,j指向终止位置

class Solution {
public:vector<int> sortedSquares(vector<int>& nums) {int k = nums.size() - 1;vector<int> result(nums.size(),0);for(int i = 0,j = nums.size() - 1 ;i <= j ; ){if((nums[i] * nums[i]) > (nums[j] * nums[j])){result[k--] = nums[i] *nums[i];i++;}else{result[k--] = nums[j] * nums[j];j-- ;}}return result; //最终返回排序好的平方和数组}
};

最终返回排序好的平方和数组。

http://www.ds6.com.cn/news/25064.html

相关文章:

  • 邯郸市开网店儿网络公司排名优化百度
  • 平台网站建设公司哪家好媒体资源网
  • 小清新网站源码by72777最新域名查询
  • 怎么做一个商城网站怎么有自己的网站
  • 保定网站制作400办理网络营销师培训费用是多少
  • 网站建设模板双人如何制作企业网站
  • 公众号网页制作模板厦门seo优化公司
  • 网站开发用什么开发工具好呢网站可以自己建立吗
  • 国际版网站可以在国内做推广吗设计公司企业网站
  • 合肥微网站建设企业网站营销的优缺点及案例
  • 做易拉宝设计的网站外贸高端网站设计公司
  • 本地电脑做网站服务器武汉seo首页优化报价
  • 硬件开发一站式平台在线检测网站安全
  • 做二手车放在哪个网站好营销咨询顾问
  • 深圳外贸建站与推广网络推广方法有哪些
  • 怎么样建立网站方案自动化测试培训机构哪个好
  • 网站导航cms友情链接分析
  • 游戏开发大亨内购破解版兰州seo实战优化
  • wordpress区别百度seo关键词排名技术
  • 什么网站可以做直播专业seo优化公司
  • 海外高端网站建设seo综合查询站长工具关键词
  • 国外b2b网站毛片长春seo优化企业网络跃升
  • 做详情页网站app推广拉新工作可靠吗
  • vs做网站连数据库石家庄疫情防控最新政策
  • 北京网站建设手机app软文自动发布软件
  • 二手车为什么做网站外贸推广如何做
  • 自己建网站需要什么软件营销型网站模板
  • 网站首页优化安徽网站推广公司
  • 网站智能建设系统源码产品宣传推广方案
  • 兰州市做网站建设的公司域名站长工具