旋转有序数组的二分查找
来源:互联网 发布:原生js获取index 编辑:程序博客网 时间:2024/06/10 11:58
http://hi.baidu.com/nicker2010/item/4d4f71145532a234b83180a7
总结规律,简化模型
题目都不难,重要的是很敏锐的发现问题的规律。
旋转有序数组的二分搜索,如
int arr[N] = {15,16,19,20,25,1,3,4,5,7,10,14};
查找X = 5
主要思想:
每次根据L和R求出M后,M左边[L, M]和右边[M+1, R]这两部分中至少一个是有序的。
arr[M]和X比较
(1). arr[M]==X,返回M
(2). arr[M] < arr[R],说明右侧有序,当 arr[M]<X<arr[R],则L=M+1,否则R=M-1
(3). arr[M] > arr[L],说明左侧有序,当 arr[L]<X<arr[M],则R=M-1,否则L=M+1
简单代码:
int CirculateBSearch(const int* arr,int N,int x)
{
int L=0,R=N-1,M;
while(L <= R)
{
M = (L+R)>>1;
if(arr[M] == x) return M;
if(arr[M] <= arr[R])//arr[M]右侧是有序的
{
if(arr[M]<x && x<=arr[R])//x在有序部分的内部
L = M+1;
else R = M-1;
}
else//arr[M]左侧是有序的
{
if(x<arr[M] && arr[L]<=x)//x在有序部分的内部
R = M-1;
else L = M+1;
}
}
return -1;
}
简单测试:
const int N = 12;
int X = 5;
int arr[N] = {15,16,19,20,25,1,3,4,5,7,10,14};
cout<<"Array : ";
PrintArray(arr,N);
int index = CirculateBSearch(arr,N,X);
if(index < 0) cout<<X<<" is not found in arr.\n";
else cout<<X<<" is found in arr, index = "<<index<<endl;
- 旋转有序数组的二分查找
- 旋转有序数组的二分查找
- 旋转有序数组的二分查找
- 循环有序数组/旋转数组的二分查找
- 旋转有序的二分查找
- 有序数组的二分查找
- 有序数组的二分查找
- 有序数组的二分查找
- 有序数组或者有序数组的旋转数组 查找最小值
- 旋转数组的二分查找
- 旋转数组的二分查找
- 旋转数组的二分查找
- 旋转数组的二分查找
- 旋转数组的二分查找
- 旋转数组的二分查找
- 旋转数组的二分查找
- 有序数组\二分查找
- 有序数组二分查找
- 《linus设备驱动程序》学习之开始
- 黑马程序员 集合学习
- c语言中所有文件操作函数详解fopen、fwrite、fread、fgetc、fputc、fscanf、fprintf、ftell、fseek等函数
- Core Data 编程指南
- 阿里巴巴离职DBA职业生涯总结
- 旋转有序数组的二分查找
- stdafx介绍
- 华为上半年收入1027亿首超爱立信,成电信设备第一巨头
- [DZ平台]登录界面-无刷新验证码
- Uboot配置参数,Linxu开发中经验总结的
- poj 2396 Budget--有源汇+有上下界+可行流
- hdu 1054
- 学习笔记之ofstream 和ifstream的具体用法
- HDU-1548-A strange lift