今天闲着没事,刷了几道二分的题目。
刷题之前我想:二分,就这?两分钟就写一道题。
但是没想到,做了几道题之后,还能卡我一手。

题目一

https://leetcode-cn.com/problems/binary-search/

LeetCode704. 二分查找
给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1。

示例 1:

输入: nums = [-1,0,3,5,9,12], target = 9
输出: 4
解释: 9 出现在 nums 中并且下标为 4
示例 2:

输入: nums = [-1,0,3,5,9,12], target = 2
输出: -1
解释: 2 不存在 nums 中因此返回 -1

提示:

你可以假设 nums 中的所有元素是不重复的。
n 将在 [1, 10000]之间。
nums 的每个元素都将在 [-9999, 9999]之间。

AC代码

class Solution {public:int search(vector<int>& nums, int target) {int left = 0;int right = nums.size() - 1;while (left <= right)// 这里三种情况都判断了,可以用<={// 这里暂时没有用到,但是下一题会卡一个数据范围。int mid = left + (right - left) / 2;if (nums[mid] == target){return mid;}else if(nums[mid] < target){left = mid + 1;}else{right = mid - 1;}}return -1;}
};

建议亲手尝试一下这道题,然后,看之后两道题。

题目二

https://leetcode-cn.com/problems/first-bad-version/

LeetCode278. 第一个错误的版本
你是产品经理,目前正在带领一个团队开发新的产品。不幸的是,你的产品的最新版本没有通过质量检测。由于每个版本都是基于之前的版本开发的,所以错误的版本之后的所有版本都是错的。

假设你有 n 个版本 [1, 2, …, n],你想找出导致之后所有版本出错的第一个错误的版本。

你可以通过调用 bool isBadVersion(version) 接口来判断版本号 version 是否在单元测试中出错。实现一个函数来查找第一个错误的版本。你应该尽量减少对调用 API 的次数。

示例 1:

输入:n = 5, bad = 4
输出:4
解释:
调用 isBadVersion(3) -> false
调用 isBadVersion(5) -> true
调用 isBadVersion(4) -> true
所以,4 是第一个错误的版本。
示例 2:

输入:n = 1, bad = 1
输出:1

提示:

1 <= bad <= n <= 231 - 1

AC代码

// The API isBadVersion is defined for you.
// bool isBadVersion(int version);class Solution {public:int firstBadVersion(int n) {int left = 1;int right = n;while (left < right)// 不加等号的话,最后得到的结果left和right应该是相等的{int mid = left + (right - left) / 2;if (isBadVersion(mid)){right = mid;}else{left = mid + 1;}}return left;}
};

这个出了加了一些数据范围的处理之外,判断条件也略有不同,二分并不是千篇一律的,思想是不变的,代码可以灵活处理不同的情况。

题目三

https://leetcode-cn.com/problems/search-insert-position/

LeetCode35. 搜索插入位置
给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。

请必须使用时间复杂度为 O(log n) 的算法。

示例 1:

输入: nums = [1,3,5,6], target = 5
输出: 2
示例 2:

输入: nums = [1,3,5,6], target = 2
输出: 1
示例 3:

输入: nums = [1,3,5,6], target = 7
输出: 4
示例 4:

输入: nums = [1,3,5,6], target = 0
输出: 0
示例 5:

输入: nums = [1], target = 0
输出: 0

提示:

1 <= nums.length <= 104
-104 <= nums[i] <= 104
nums 为无重复元素的升序排列数组
-104 <= target <= 104

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

这个跟之前的又不太一样,所以,还是需要一点点灵活处理的,算法真好玩,简单的题目也可以做到如此精妙无比的变化,看来接下来一段时间,可以好好的玩一玩这些算法题目了。

小小的面试二分题目,竟然暗藏玄机?相关推荐

  1. 【Android】 一个crash 背后竟然暗藏玄机,速看!

    导读 最近公司有一个需求,就是如何让App 不奔溃或者奔溃后可以自动重启?咋一听,可能你和我都会说,对可能Crash的地方try-catch 不就可以了? 然而细琢磨一下这个问题,其实并非如此简单.. ...

  2. Java高级程序员(5年左右)面试的题目集

    Java高级程序员(5年左右)面试的题目集 https://blog.csdn.net/fangqun663775/article/details/73614850?utm_source=blogxg ...

  3. CSS3中:nth-child和:nth-of-type的区别深入理解。 关于:nth-child和:nth-of-type的区别之前一直没太注意,经深入理解才发现里面其实暗藏玄机...

    关于:nth-child和:nth-of-type的区别之前一直没太注意.最近打算深入了解一些CSS3,才发现里面其实暗藏玄机. :nth-child可以选择父元素下的字元素,:nth-of-type ...

  4. iOS 面试基础题目

    转载: iOS 面试基础题目 题目来自博客:面试百度的记录,有些问题我能回答一下,不能回答的或有更好的回答我放个相关链接供参考. 1面 Objective C runtime library:Obje ...

  5. C++内存问题(很多公司面试的题目,值得一看,看懂了别忘了告诉我)

    C++内存问题(很多公司面试的题目,值得一看,看懂了别忘了告诉我) void GetMemory(char *p) { p=(char*)malloc(100); } void Test(void) ...

  6. 软件面试常见题目(转帖)

    软件面试常见题目(转帖)   1.什么是兼容性测试?兼容性测试侧重哪些方面? 参考答案: 兼容测试主要是检查软件在不同的硬件平台.软件平台上是否可以正常的运行,即是通常说的软件的可移植性. 兼容的类型 ...

  7. 小学计算机面试试讲题目,小学数学教师资格证面试试讲题目

    注意:大家在准备写教案的时候,如果时间来不及,可以简单点,但是要每一步都要写,这样能提高印象分.下面库课李老师给考生整理了小学数学教师资格证面试试讲题目,考生在考前可先来看看. 一般步骤:1.题目.2 ...

  8. 非常带感的武汉周边一日游行政主管提示你这封作品暗藏玄机

    每个人的人生不可能总会一帆风顺,工作,学习生活多余应该要多出去走走才是,生活中是如此,说走就走的旅行亦是如此,身体和灵魂总有一个出发在路上,田园般的恬静生活很多人都很向往哦.非常带感的武汉周边一日游行 ...

  9. MySQL面试常见题目(六)

    原文地址:MySQL面试常见题目(六) 1.字段为何需定义NOT NULL? NULL会占用更多字节,且NULL有很多坑. 2.如需存储用户密码散列,应使用什么字段? 应使用char,可节省空间且提高 ...

最新文章

  1. Git 的简单使用及ssh配置问题-赖大大
  2. Java并发机制底层实现原理-volatile
  3. C++关于虚基类、构造函数、析构函数、成员对象的两个程序浅析
  4. FFMpeg分析详细分析
  5. 物体检测 | 29篇顶会(刊)论文集
  6. 练习-CSS3 多栏(Multi-column)
  7. python 爬虫代码实例
  8. [ openwrt ] 添加一个通过GPIO控制的LED
  9. IPv6下一代互联网现在就出发!
  10. Google Guava学习(10)-Guava字符串工具CharMatcher
  11. 利用ode45求解含控制量并且控制量为离散点的动力学方程
  12. 第二类斯特林数 - Push Botton Lock(POJ 3088)
  13. 为什么要写书?出版图书有哪些好处?
  14. 修改Android10系统源码关闭selinux
  15. 【图文教程】文件压缩和打包
  16. 一、AutoCAD 2013建筑设计师装潢施工设计篇 基本知识
  17. LKD3568 Android11 系统架包使用步骤
  18. OCR文字识别标记软件--使用说明
  19. jQuery bind(绑定事件)前别忘了unbind(移除事件)
  20. Canoe 安装流程

热门文章

  1. leveldb:Arena浅析
  2. vlookup反向查询_VLOOKUP的反向查找功能
  3. 公司出路:与速达ERP合作设想
  4. 李飞飞CS231n2017课程双语字幕版上线 !(附课程链接)
  5. VS2022安装教程(超详细)
  6. GoogleTest使用教程
  7. 2018.11.15 《黄金时代》王小波
  8. adb wifi连接android设备
  9. XiaoHu.ai开发日志(自2018年2月6日至2019年4月11日)
  10. python中的对象是什么意思_python中什么是对象