my understanding of (lower bound,upper bound) binary search, in C++, thanks to two post 分类: leetcode 2015-08-01 14:35 113人阅读 评论(0) 收藏
If you understand the comments below, never will you make mistakes with binary search! 
thanks to A simple CPP solution with lower_bound 
and C++ O(logn) Binary Search that handles duplicate,  thanks to phu1ku ‘s answer on the second post. 
http://en.cppreference.com/w/cpp/algorithm/upper_bound 
Returns an iterator pointing to the first element in the range [first, last) that is greater than value.  
http://en.cppreference.com/w/cpp/algorithm/lower_bound 
Returns an iterator pointing to the first element in the range [first, last) that is not less than (i.e. greater or equal to) value.
If want to practice, code on your own, try https://leetcode.com/problems/search-insert-position/ , https://leetcode.com/problems/find-minimum-in-rotated-sorted-array/ , https://leetcode.com/problems/find-minimum-in-rotated-sorted-array-ii/ and https://leetcode.com/problems/search-a-2d-matrix-ii/ , and see the discusses.
int binarySearch(vector<int>& nums, int target) {
    /// return index of first one that comp(item,target)==true, or nums.size() if not found
    /// comp is greater or equal to for lower_bound
    /// comp is greater for upper_bound
    int first=0, last=nums.size(), mid;
    while (first<last) {
        mid=first+((last-first)>>1); // first<=mid, mid<last
        /// if comp(item,target)==false, advance first
        // if(nums[mid]<=target) // for upper_bound
        if (nums[mid]<target) // for lower_bound
        first=mid+1; // first always increases
        else /// else recede last
        last=mid; // last always decreases (even last-first==1)
    }
    return first;
}版权声明:本文为博主原创文章,未经博主允许不得转载。// p.s. If in any way improment can be achieved, better performance or whatever, it will be well-appreciated to let me know, thanks in advance.
my understanding of (lower bound,upper bound) binary search, in C++, thanks to two post 分类: leetcode 2015-08-01 14:35 113人阅读 评论(0) 收藏的更多相关文章
- POJ2566 Bound Found                                                                                            2017-05-25 20:05             32人阅读              评论(0)              收藏
		Bound Found Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 4056 Accepted: 1249 Spe ... 
- Binary Tree                                                       分类:            POJ             2015-06-12 20:34    17人阅读    评论(0)    收藏
		Binary Tree Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 6355 Accepted: 2922 Descr ... 
- Binary Indexed Tree 2D                                                    分类:            ACM TYPE             2014-09-01 08:40    95人阅读    评论(0)    收藏
		#include <cstdio> #include <cstdlib> #include <climits> #include <cstring> # ... 
- Binary Indexed Tree                                                    分类:            ACM TYPE             2014-08-29 13:08    99人阅读    评论(0)    收藏
		#include<iostream> #include<cstring> #include<cstdio> using namespace std; int n, ... 
- 数据结构之Binary Search Tree (Java)
		二叉查找树简介 二叉查找树(Binary Search Tree), 也成二叉搜索树.有序二叉树(ordered binary tree).排序二叉树(sorted binary tree), 是指一 ... 
- [LeetCode] 95. Unique Binary Search Trees II 唯一二叉搜索树 II
		Given n, generate all structurally unique BST's (binary search trees) that store values 1...n. For e ... 
- leetcode 96. Unique Binary Search Trees 、95. Unique Binary Search Trees II 、241. Different Ways to Add Parentheses
		96. Unique Binary Search Trees https://www.cnblogs.com/grandyang/p/4299608.html 3由dp[1]*dp[1].dp[0]* ... 
- 二分查找里的upper bound与lower bound的实现与分析
		1. 问题引入 最近参选了学堂在线的课程数据结构(2015秋).课程由清华大学的邓俊辉老师主讲,在完成课后作业时,遇到了这样一个题目范围查询.在这个题目中,我需要解决这样一个子问题:给定了一组已经排好 ... 
- PKU2018校赛 H题 Safe Upper Bound
		http://poj.openjudge.cn/practice/C18H 题目 算平均数用到公式\[\bar{x}=\frac{x_1+x_2+x_3+\cdots+x_n}{n}\] 但如果用in ... 
随机推荐
- 慕课网__CSS__vertical align
- python & c
			http://www.ibm.com/developerworks/cn/linux/l-cn-pythonandc/ 
- 【Hector slam】A Flexible and Scalable SLAM System with Full 3D Motion Estimation
			作者总结了SLAM前端和后端的区别 While SLAM frontends are used to estimate robot movement online in real-time, the ... 
- node config
			@echo off title node_5560 cd /d %~dp0 java -jar selenium-server-standalone-.jar ^ -role node ^ -Dweb ... 
- HTML5Viewer中如何运行时绑定多数据源
			很多报表控件提供HTML5Viewer 支持跨设备的报表系统,当然在很多情况下,一个系统可包含多个报表文件,这些报表的数据有可能均为运行时绑定数据源,那么在html5viewer中对一张报表通过重写W ... 
- Git常用命令速查表
- openxml(二)  添加页眉,页脚
			openxml 中 word 文档的结构是如下图: 其中,页眉是 header,属于headerpart 部件,页脚是footer,属于footerpart 部件,图上还有其他的东西,之后会一一介绍. ... 
- 做为一名PHP程序员,应该关注的互联网IT大牛!
			俗话说:“读万卷书不如行万里路,行万里路不如高人指路”,做为一名新人,以后的路还很长,多年你的成就取决于今天的自己付出,选中自己的方向比什么都重要,关注大牛,向他们学习,才不会迷失自己! 1.惠新宸( ... 
- JAVA类与对象
			Employee类: public class EmployeeTest { public static void main(String[] args) { // fill the staff ar ... 
- JavaScipt 样式操作
			我们知道HTML样式定义的三种方式: <link/>外部引入也就是定义 CSS 中的 <style/>嵌入式样式 style特性地定义 给一个HTML元素设置css属性,如: ... 
