【算法刷题day1】Leetcode:704. 二分查找、27. 移除元素

Leetcode 704:标准二分查找

文档讲解:代码随想录
题目链接:704.二分查找
状态:稳定输出

题目:
给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1。
示例:
在这里插入图片描述
思路: 标准二分查找
注意:
1)l 和 r 两个变量的取值范围以及循环的跳出条件
2)mid 的取值方法为了防止溢出采用 mid = l + (r-l) / 2;

class Solution {
public:int search(vector<int>& nums, int target) {int size = nums.size();int l = 0;int r = size - 1;int mid;while(l <= r){mid = l + (r-l) / 2;if(nums[mid] == target){return mid;}else if(nums[mid] > target){r = mid - 1;}else {l = mid + 1;}}return -1;}
};

Leetcode 27:移除元素

文档链接:代码随想录
题目链接:27.移除元素
状态:for循环能出bug我也是头子

题目:
给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度。
不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并 原地 修改输入数组。
元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。
示例:
在这里插入图片描述
思路:
快慢指针的问题
注意:
1.快指针指的是遍历所有元素,而慢指针才是指向真正删除元素之后的新数组。
2.else当中的continue省去会增加时长(好神奇)
在这里插入图片描述

class Solution {
public:int removeElement(vector<int>& nums, int val) {int size = nums.size();int lowerindex = 0;int fastindex = 0;for(fastindex = 0; fastindex < size ; fastindex++){if(nums[fastindex] != val){nums[lowerindex] = nums[fastindex];lowerindex++;}else{continue;}}return lowerindex;}
};

以下补充一些相关的题目

二分法

35. 搜索插入位置

题目:
给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
请必须使用时间复杂度为 O(log n) 的算法。
注意:
1.其实这个最后插入位置的输出结果不太好找,有一个方法就是如果数组里没有target时,最后 l = r 的位置一定是插入位置之后的一位,同时nums[mid] > target一定会导致最后一步 r - 1,所以最后返回的位置值可以确定。
2.还有两边边界的相关条件判断

class Solution {
public:int searchInsert(vector<int>& nums, int target) {int size = nums.size();if(target < nums[0]) return 0;else if(target > nums[size - 1]) return size;int l = 0;int r = size - 1;int mid;while(l <= r){mid = l + (r - l) / 2;if(nums[mid] == target){return mid;}else if(nums[mid] > target){r = mid - 1;}else{l = mid + 1;}}return r + 1;}
};

34. 在排序数组中查找元素的第一个和最后一个位置

题目:
给你一个按照非递减顺序排列的整数数组 nums,和一个目标值 target。请你找出给定目标值在数组中的开始位置和结束位置。
如果数组中不存在目标值 target,返回 [-1, -1]。你必须设计并实现时间复杂度为 O(log n) 的算法解决此问题。
注意:
1.这道题暂时只会用分别寻找左右边界的方法,需要注意寻找的方式
2.左边界由r指针赋值,无论是target小于还是等于nums[mid]都更新r的取值范围,需要理解这么做的原因
(times * 2)

class Solution {
public:vector<int> searchRange(vector<int>& nums, int target) {int left = findleft(nums, target);int right = findright(nums, target);if(left == -2 || right == -2) return {-1, -1};if((right - left) >= 2) return {left + 1, right - 1};return {-1,-1};}
private:int findleft(vector<int>& nums, int target){int l = 0;int r = nums.size() - 1;int mid;int left = -2;while(l <= r){mid = l + (r - l) / 2;if(nums[mid] < target){l = mid + 1;}else{r = mid - 1;left = r;}}return left;}int findright(vector<int>& nums, int target){int l = 0;int r = nums.size() - 1;int mid;int right = -2;while(l <= r){mid = l + (r - l) / 2;if(nums[mid] > target){r = mid - 1;}else{l = mid + 1;right = l;}}return right;}
};

69.x的平方根

题目:
给你一个非负整数 x ,计算并返回 x 的 算术平方根 。
由于返回类型是整数,结果只保留 整数部分 ,小数部分将被 舍去 。
注意:不允许使用任何内置指数函数和算符,例如 pow(x, 0.5) 或者 x ** 0.5 。
注意:
1.在计算平方的时候要使用除法代替,否则容易超范围

class Solution {
public:int mySqrt(int x) {if(x == 0) return 0;if(x == 1) return 1;int l = 0;int r = x;int mid;while(l <= r){mid = l + (r - l) / 2;if(x / mid > mid){l = mid + 1;}else if(x / mid < mid){r = mid - 1;}else return mid;}return r;}
};

367.有效的完全平方数

题目: 给你一个正整数 num 。如果 num 是一个完全平方数,则返回 true ,否则返回 false 。
完全平方数 是一个可以写成某个整数的平方的整数。换句话说,它可以写成某个整数和自身的乘积。
不能使用任何内置的库函数,如 sqrt 。
注意:
1.这个就是上面那个所说的超范围,但这回不能用除法,因为/默认是向下取整。可以更改int为long long。

class Solution {
public:bool isPerfectSquare(int num) {if (num == 1)return true;long long l = 1;long long r = num;long long mid;while (l <= r) {mid = l + ((r - l) / 2);if (mid * mid == num) {return true;} else if (num / mid > mid) {r = mid - 1;} else {l = mid + 1;}}return false;}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/760276.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在Linux环境底下 用C语言执行Python程序

在Linux环境底下 用C语言执行Python程序 文章目录 在Linux环境底下 用C语言执行Python程序1、环境安装&检测2、C语言调用Python语句2.1 直接调用python语句2.2 调用无参python函数2.3 调用有参python函数 1、环境安装&检测 通过C语言调用Python代码&#xff0c;需要先安…

springboot企业级抽奖项目业务二(用户模块)

书接上回&#xff0c;梅开二度 开发流程 该业务基于rouyi生成好了mapper和service的代码&#xff0c;现在需要在controller层写接口 实际操作流程&#xff1a; 看接口文档一>controller里定义函数一>看给出的工具类一>补全controller里的函数一>运行测试 接口…

rust 文件引用,父目录下的同级目录之间的引用

父目录下的同级目录之间的引用 例如有&#xff1a; src/component/aaa.rs src/component/mod.rs // 有 pub mod aaa; src/module/bbb.rs src/module/mod.rs // 有 pub mod bbb; src/main.rs // 有 mod module;如果 bbb.rs要引用aaa.rs&#xff1a; 在main.rs再加上mod compo…

如何快速用docker run启动一个linux环境(debian/ubuntu)

如何快速用docker run启动一个linux环境&#xff08;debian/ubuntu&#xff09; 文章目录 前言正文拉取镜像启动镜像 总结 前言 如何快速启动一个docker环境用于调式或相关用途&#xff0c;该环节具备某一特定系统所有相关组件及依赖库&#xff0c;并将本地目录挂载到目标路径…

C++基础部分

万能模板 #include<bits/stdc.h> 数组长度 size_t n sizeof(a)/sizeof(a[0]);控制台输入数据的处理 &#xff08;1&#xff09;字符串——getline(cin,s) #include<bits/stdc.h> using namespace std;int main() {string s1,s2;getline(cin,s1);getline(cin,s…

【数据结构】堆和树详解堆和二叉树的实现堆的top-k问题

主页&#xff1a;醋溜马桶圈-CSDN博客 专栏&#xff1a;数据结构_醋溜马桶圈的博客-CSDN博客 gitee&#xff1a;mnxcc (mnxcc) - Gitee.com 目录 1.树概念及结构 1.1 树的概念 2.2 树的相关概念 1.3 树的表示 1.4 树在实际中的运用 2.二叉树的概念及结构 2.1 二叉树的概念…

vue前端解析jwt

vue前端解析jwt 我们可以用在线解析看解析的结果&#xff1a;https://www.lddgo.net/encrypt/jwt-decrypt 但是如果在前端需要解析token&#xff0c;拿到其中的权限信息&#xff0c;可以这样解决。 在线的&#xff1a; 完美解决&#xff1a; 代码&#xff1a; function par…

MySQL | 表的约束

目录 1. 空属性 NULL 2. 默认值 DEFAULT 3. 列描述comment 4. zerofill 5. 主键 PRIMARY KEY 6. 自增长AUTO_INCREMENT 7. 唯一键UNIQUE 8. 外键 真正约束字段的是数据类型&#xff0c;但是数据类型约束很单一&#xff0c;需要有一些额外的约束&#xff0c;更好的保证数…

web前端常用标签(html)

1.定义 1.1标签 语法规范&#xff1a;<标签名 属性名"属性值">标签名</标签名> 标签之间可以嵌套 1.2属性 定制元素的行为的。属性是不通用的&#xff0c;每一个标签存在自身的属性。当属性名属性值时&#xff0c;可以只写属性值 2.HTML常用标签 2…

前端项目构建过程中涉及低代码部分思考

表单常见的增删查改的重复问题解决 1市面上有很多表单设计器与框架进行结合&#xff0c;封装一个表单组件&#xff0c;结合响应式&#xff0c;然后给到我们下载使用 2修改起来很麻烦&#xff0c;有局限&#xff0c;但我们可以参考他们的思路&#xff0c;来设计符合项目的组件来…

面试笔记——Redis(分布式锁的使用场景及实现原理)

分布式锁的使用场景 资源竞争控制&#xff1a;多个客户端同时访问共享资源时&#xff0c;可以使用分布式锁来控制资源的并发访问&#xff0c;防止多个客户端同时对同一资源进行修改造成数据不一致的问题。 避免重复操作&#xff1a;在分布式环境中&#xff0c;可能会出现多个客…

算法51:动态规划专练(力扣139题,单词拆分)---从左往右尝试模型的误区

题目&#xff1a; 给你一个字符串 s 和一个字符串列表 wordDict 作为字典。如果可以利用字典中出现的一个或多个单词拼接出 s 则返回 true。 注意&#xff1a;不要求字典中出现的单词全部都使用&#xff0c;并且字典中的单词可以重复使用。 示例 1&#xff1a; 输入: s &qu…

如何实现手机遥控端关机按钮同时关闭TV端和手机端界面

目前家庭电视机主要通过其自带的遥控器进行操控&#xff0c;实现的功能较为单一。例如&#xff0c;当我们要在TV端搜索节目时&#xff0c;电视机在遥控器的操控下往往只能完成一些字母或数字的输入&#xff0c;而无法输入其他复杂的内容。分布式遥控器将手机的输入能力和电视遥…

基于springboot+vue的智慧生活商城系统

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战&#xff0c;欢迎高校老师\讲师\同行交流合作 ​主要内容&#xff1a;毕业设计(Javaweb项目|小程序|Pyt…

Pytest自动化测试执行环境切换的两种解决方案(超详细)

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 点击文末小卡片 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 痛点分析 在实际企业的项目中&#xff0c;自动化测试的代码往往需要在不同的环境中进行切换&am…

蓝桥:重新排序(差分,python)

前言&#xff1a; 本题在模拟考试时还不会差分法&#xff0c;用纯暴力思路ac了60%的案列&#xff0c;之后看了蓝桥讲解&#xff0c;用差分做出来了&#xff08;但对差分还是一知半解&#xff09;&#xff0c;最近学会了差分又来做本题&#xff0c;又卡在了技巧思路上&#xff…

【超细完整版】C# WebService 通过URL生成WSDL文件和DLL文件 【生成篇】

目的 支持通过web url (自适应“?wsdl”的有无) 生成.wsdl文件 和 .dll文件 实现 将通过一个类的三部分来实现这些功能 获取url中的ClassName &#xff08;GetClassNameFromUrl&#xff09;转换为WSDL文件 &#xff08;UrlToWsdlFile&#xff09;转换为DLL文件 &#xff08;…

【算法】数组-二分搜索法

对应力扣704题目 左闭右闭 public class Solution{ public static void main(String[] args){ int[] nums {1,2,3,4,5,6,7,8,9,10}; int target 5; Solution solution new Soulution(); int result solution.search( nums, target); System.out.println("找到值的位置…

利用代理IP突破地域限制:解锁全球网络访问攻略

利用代理IP突破地域限制&#xff0c;实现解锁全球网络访问&#xff0c;是一种常见的网络技术手段。以下是一份详细的攻略&#xff1a; 1. 理解代理IP&#xff1a; 代理IP就像一个中间人&#xff0c;你的请求先发送到代理服务器&#xff0c;然后由代理服务器去获取你想要访问的网…

【STL基础】vector、stack、queue、list、pair、map、unordered_map、set、unordered_set(详细讲解)

vector、list、pair、unordered_map、unordered_set、stack、queue 参考文章&#xff1a; &#xff08;1&#xff09;【apollo】泛型编程 与 STL &#xff08;2&#xff09;c stack用法 入门必看 超详细 &#xff08;3&#xff09;C中queue的用法&#xff08;超详细&#xff0c…