亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

leecode 解題總結:33. Search in Rotated Sorted Array

2019-11-10 19:33:08
字體:
來源:轉載
供稿:網友
#include <iostream>#include <stdio.h>#include <vector>using namespace std;/*問題:Suppose an array sorted in ascending order is rotated at some pivot unknown to you beforehand.(i.e., 0 1 2 4 5 6 7 might become 4 5 6 7 0 1 2).You are given a target value to search. If found in the array return its index, otherwise return -1.You may assume no duplicate exists in the array.分析:這是程序員面試金典的一道題目。是在旋轉數組中查找一個元素。設數組為A,長度為len,設查找元素為target,設旋轉的樞軸為pivot,初始low=0,high=len-1mid = low + (high-low)/2; 如果A[low] < target,那么元素只可能在旋轉數組的左側部分(因為A[low]~A[pivot]是升序的,A[pivot+1]~A[high]是升序的,且A[0]>A[len-1])  令high = mid如果A[low] > target,元素在旋轉數組的右側部分  令low = midA[low] = target,找到元素,返回lowlow > high,返回-1,表示找不到輸入:7 64 5 6 7 0 1 27 24 5 6 7 0 1 27 34 5 6 7 0 1 26 32 3 2 2 2 26 32 2 2 2 3 26 32 2 2 2 2 4輸出:26-114-1關鍵:1 需要用中間元素和兩邊元素比較來確定哪一邊是升序,并根據升序兩側大小和給定值比較,確定最終在A[low] < A[mid]說明左邊是升序,例如4 5 6 7 0 1 2,如果有A[low] <= target <= A[high],則在左半部分尋找A[low] > A[mid]說明右邊是升序,例如5 6 7 0 1 2 42左邊=中間 != 右邊,在右半部分查找 左邊=中間 = 右邊,先左半部分查找,如果左半部分查找不到,查找右半部分*/class Solution {public:    int searchRotation(vector<int>& nums, int target ,int low ,int high) {        if(nums.empty() ||low < 0 || high >= nums.size() || low > high)		{			return -1;		}		int mid;		if(low < high)		{			mid = low + (high - low)/2;			//找到元素			if(nums.at(mid) == target)			{				return mid;			}			//左半部分升序			if(nums.at(low) < nums.at(mid))			{				//在左半部分升序中				if( nums.at(low) <= target && target <= nums.at(mid))				{					//high = mid;					return searchRotation(nums, target , low , mid);				}				//在右半部分中尋找				else				{					//low = mid + 1;					return searchRotation(nums , target , mid + 1 , high);				}			}			//右半部分升序			else if(nums.at(low) > nums.at(mid))			{				//在右半部分升序中				if(nums.at(mid) <= target && target <= nums.at(high))				{					//low = mid;					return searchRotation(nums , target , mid , high);				}				else				{					//high = mid - 1;					return searchRotation(nums , target , low , mid - 1);				}			}			//左邊等于中間,可能low=high=mid時進入			else			{				//如果左邊!=右邊,查找右半部分				if(nums.at(low) != nums.at(high))				{					//low = mid + 1;					return searchRotation(nums , target , mid + 1, high);				}				//左邊=中間=右邊,先查左半部分,再查右半部分				else				{					int result = searchRotation(nums , target , low , mid);					if(-1 != result)					{						return result;					}					else					{						return searchRotation(nums , target , mid + 1 , high);					}				}			}		}		//low == high		else		{			if(nums.at(low) == target)			{				return low;			}			else			{				return -1;			}		}    }    int search(vector<int>& nums, int target) {        if(nums.empty())		{			return -1;		}		int len = nums.size();		int low = 0;		int high = len - 1;		int result = searchRotation(nums , target , low , high);		return result;    }};void PRocess(){	int value;	int num;	vector<int> datas;	int searchValue;	while(cin >> num >> searchValue)	{		datas.clear();		for(int i = 0 ; i < num ; i++)		{			cin >> value;			datas.push_back(value);		}		Solution solution;		int result = solution.search(datas , searchValue);		cout << result << endl;	}}int main(int argc , char* argv[]){	process();	getchar();	return 0;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品亚洲欧美导航| 欧美一区三区三区高中清蜜桃| 欧美男插女视频| xxxx性欧美| 中文字幕v亚洲ⅴv天堂| 红桃视频成人在线观看| 欧美激情二区三区| 国产日韩欧美黄色| 久久久久久久久久久久久久久久久久av| 91av在线不卡| 欧美精品久久久久a| 91欧美精品午夜性色福利在线| 欧美一区三区三区高中清蜜桃| 亚洲精品99久久久久| 亚洲另类欧美自拍| 久久人人爽国产| 亚洲电影免费观看高清| 国产日韩av在线| 日韩欧美一区视频| 久久天天躁狠狠躁夜夜躁2014| 午夜欧美大片免费观看| 亚洲xxxxx| 国产精品激情自拍| 成人中心免费视频| 亚洲影影院av| 国产精品美乳在线观看| 这里只有精品久久| 97视频在线观看免费高清完整版在线观看| 亚洲欧美国产高清va在线播| 欧美精品久久久久久久久| 久久精品久久久久久国产 免费| 久久久久久网站| 在线成人激情黄色| 国产精品久久一区| 日韩激情av在线播放| 欧美精品激情blacked18| 97在线观看免费| 久久在线观看视频| 一道本无吗dⅴd在线播放一区| 96sao精品视频在线观看| 国产欧美在线播放| 日韩大胆人体377p| 成人黄色av免费在线观看| 国产精品美女主播在线观看纯欲| 日韩美女在线观看一区| 日本中文字幕不卡免费| 亚洲第一视频在线观看| 国产香蕉精品视频一区二区三区| 午夜精品蜜臀一区二区三区免费| 国产精品久久久久久五月尺| 国模吧一区二区| 精品国产欧美成人夜夜嗨| 中文字幕欧美日韩精品| 欧美亚洲在线观看| 久久99久久99精品免观看粉嫩| 国产美女久久精品香蕉69| 亚洲黄色www网站| 国产精品嫩草影院久久久| 国产精品999| 91免费视频网站| 不卡伊人av在线播放| 欧美日韩另类视频| 欧美裸身视频免费观看| 欧美大码xxxx| 国产免费一区二区三区在线观看| 久久免费高清视频| 日韩三级成人av网| 精品久久久久久中文字幕一区奶水| 亚洲精品免费av| 97视频网站入口| 久久视频在线直播| 国产精品久久久久久久久久| 亚洲欧美成人一区二区在线电影| 中文字幕精品国产| 日韩女优人人人人射在线视频| 国内精品久久久| 久久天天躁日日躁| 国产精品久久久久久久久借妻| 欧美激情一二区| 亚洲国产一区二区三区在线观看| 亚洲欧洲一区二区三区在线观看| 久久6免费高清热精品| 中文字幕亚洲欧美在线| 91精品国产高清自在线看超| 国色天香2019中文字幕在线观看| 欧美专区第一页| 国产在线高清精品| 亚洲精品动漫100p| 97在线视频国产| 久久久久久久久久久久av| 国产成人aa精品一区在线播放| 午夜精品久久久久久久99黑人| 一区二区三区www| 欧美另类99xxxxx| 久久精品视频在线播放| 97色在线视频| 91九色在线视频| 北条麻妃一区二区三区中文字幕| 69国产精品成人在线播放| 国产z一区二区三区| 日韩精品在线观看一区| 亚洲香蕉在线观看| 欧美电影免费播放| 欧美激情第1页| 日韩欧美国产激情| 日韩一区二区欧美| 国产成人高清激情视频在线观看| 精品中文视频在线| 国产精品极品美女粉嫩高清在线| 成人免费激情视频| 国产成人久久久| 国产日韩精品在线播放| 久久久精品久久| 91高清视频免费| 色噜噜狠狠狠综合曰曰曰88av| 91成人福利在线| 91av在线看| 97在线视频免费看| 一道本无吗dⅴd在线播放一区| 亚洲男女自偷自拍图片另类| 日韩av电影院| 最新日韩中文字幕| 日韩中文字幕国产| 国产91精品久久久久久久| 国产精彩精品视频| 国产精品69久久久久| 精品亚洲一区二区三区四区五区| 国产精品免费观看在线| 97久久精品人搡人人玩| 一区二区三区四区在线观看视频| 国产一区二中文字幕在线看| 国产精品久久久久久久久久小说| 欧美性极品少妇精品网站| 亚洲电影免费在线观看| 精品无人区乱码1区2区3区在线| 亚洲国产日韩欧美综合久久| www.久久色.com| 欧美日韩中文字幕在线| 日韩黄色在线免费观看| 国产伦精品一区二区三区精品视频| 日韩精品视频中文在线观看| 91系列在线播放| 伊人久久五月天| 久久久免费在线观看| xxx欧美精品| 亚洲最大福利网| 日韩国产欧美区| 国产欧美精品一区二区三区-老狼| 精品女厕一区二区三区| 国产成人精品免高潮费视频| 亚洲精品成人久久电影| 国产精品中文久久久久久久| 亚洲伦理中文字幕| 国产成人精品久久亚洲高清不卡| 欧美日韩国产限制| 中文字幕日韩av综合精品| 亚洲国产毛片完整版| 亚洲影院高清在线| 亚洲欧美日韩爽爽影院| 久久综合国产精品台湾中文娱乐网| 色综合老司机第九色激情| 91免费在线视频网站| 久久69精品久久久久久国产越南| 国产91网红主播在线观看|