LeetCode(35) Search Insert Position
2015-08-17 16:28
525 查看
题目
Given a sorted array and a target value, return the index if the target is found. If not, return the index where it would be if it were inserted in order.You may assume no duplicates in the array.
Here are few examples.
[1,3,5,6], 5 → 2
[1,3,5,6], 2 → 1
[1,3,5,6], 7 → 4
[1,3,5,6], 0 → 0
分析
此题目与上一个题目类似都是源于二分查找的变形。若序列中存在目标元素值,则直接返回其下标,若不存在则返回第一个大于它的元素的下标,只需要在二分搜索算法中稍微修改即可。
AC代码
class Solution { public: int searchInsert(vector<int>& nums, int target) { if (nums.size() == 0) return 0; else if (nums.size() == 1) { if (nums[0] >= target) return 0; else return 1; } else{ return BinarySearch(nums, target); } } int BinarySearch(vector<int> & nums, int target) { int left = 0, right = nums.size() - 1; while (left <= right) { int mid = (left + right) / 2; if (nums[mid] == target) return mid; else if (nums[mid] < target) { if (mid == right || nums[mid + 1] > target) return mid + 1; else left = mid + 1; } else{ if (mid == left || nums[mid - 1] < target) return mid; else right = mid - 1; } }//while return -1; } };
GitHub测试程序源码
相关文章推荐
- Pushing Boxes (poj 1475 嵌套bfs)
- 系统默认只有一张内置的静态壁纸,如如何修改可以内置多张静态壁纸
- SQL 规范
- 求二叉树节点的最大差值
- #和##在宏替换中的作用
- 3.3 SELinux策略语言
- LeetCode(35) Search Insert Position
- 撞库攻击:一场需要用户参与的持久战
- DataGridView中显示图片
- select清除右侧的小三角
- SqlServer触发器详解
- 2014最新苹果开发者账号注册流程图解分享
- myFocus代码库使用方法总结
- sikuli函数、简单事件操作个人总结笔记
- java bean对象去掉所以属性两边空格
- 划分树的学习(求区间第k大的数字)
- UNITY3D学习笔记16
- 回忆是一行行无从剪接的风景
- 设计模式-观察者模式
- Codeforces 56D Changing a String 编辑距离 记忆dp