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

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

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

2019-11-10 19:07:51
字體:
來源:轉載
供稿:網友
#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
国产伦精品免费视频| 伦伦影院午夜日韩欧美限制| 米奇精品一区二区三区在线观看| 欧美高清视频在线播放| 欧美亚洲伦理www| 成人av色在线观看| 中国人与牲禽动交精品| 日韩在线观看电影| 日韩av中文字幕在线免费观看| 91香蕉电影院| 欧美成年人视频网站| 亚洲在线第一页| 少妇久久久久久| 中文国产亚洲喷潮| 久久不射电影网| 亚洲免费小视频| 性欧美xxxx交| 日韩理论片久久| 国产精品国语对白| 久久久在线视频| 国产日韩欧美在线看| 日韩在线播放视频| 国产精品jizz在线观看麻豆| 4p变态网欧美系列| 精品欧美一区二区三区| 国产激情视频一区| 狠狠综合久久av一区二区小说| 日韩精品亚洲精品| 日韩av在线最新| 欧美精品成人91久久久久久久| 日韩一区二区久久久| 日韩av在线免播放器| 狠狠色狠狠色综合日日小说| 91精品成人久久| 欧美亚洲国产精品| 日本道色综合久久影院| 2019国产精品自在线拍国产不卡| 91精品美女在线| 久久99久久99精品中文字幕| xvideos亚洲| 2019中文字幕免费视频| 91精品久久久久久久久久久久久久| 91精品视频免费观看| 亚洲欧美国产制服动漫| 8x拔播拔播x8国产精品| 亚洲成成品网站| 91免费视频网站| 欧美日韩国产中字| 成人欧美一区二区三区在线湿哒哒| 欧美小视频在线观看| 亚洲精品丝袜日韩| 97视频在线观看网址| 自拍偷拍亚洲一区| 亚洲黄色免费三级| 91国在线精品国内播放| 国产香蕉精品视频一区二区三区| 91精品国产综合久久久久久蜜臀| 欧美国产视频日韩| 777777777亚洲妇女| 久久久精品久久久| 2019中文字幕全在线观看| 青青草成人在线| 国产精品久久久久久久一区探花| 久久免费精品日本久久中文字幕| 中文字幕视频在线免费欧美日韩综合在线看| 亚洲欧美另类国产| 日本精品久久久久影院| 亚洲精品乱码久久久久久金桔影视| 欧美人交a欧美精品| 亚洲精品国产精品国自产观看浪潮| 亚洲国产成人精品久久| 中文字幕在线日韩| 日韩福利视频在线观看| 亚洲日本中文字幕免费在线不卡| 亚洲国产精品女人久久久| 欧美日韩国产综合新一区| 国产精品亚洲自拍| 高清欧美性猛交xxxx| 欧美激情视频免费观看| 色天天综合狠狠色| 欧美极品少妇xxxxⅹ裸体艺术| 亚洲精品一区二区网址| 国产乱人伦真实精品视频| 中文字幕亚洲二区| 8x拔播拔播x8国产精品| 欧美成年人视频网站| 午夜精品国产精品大乳美女| 色综合亚洲精品激情狠狠| 国产自产女人91一区在线观看| 情事1991在线| 国产日韩欧美91| 国产精品69精品一区二区三区| 91九色国产社区在线观看| 日韩精品视频中文在线观看| 亚洲v日韩v综合v精品v| 成人国产精品免费视频| 亚洲影视中文字幕| 欧美日韩一区二区三区在线免费观看| 在线观看日韩av| 亚洲丝袜一区在线| 久久69精品久久久久久久电影好| 亚洲精品一区二区久| 精品福利在线看| 国产网站欧美日韩免费精品在线观看| 国产精品一区二区女厕厕| www.欧美三级电影.com| 亚洲图片制服诱惑| 午夜精品久久久久久久久久久久久| 性欧美激情精品| 欧美激情一区二区三区成人| 亚洲性69xxxbbb| 91国内产香蕉| 日韩av在线最新| 5566成人精品视频免费| 国产一区二区三区毛片| 一本大道亚洲视频| 国产成人精品网站| 国产精品视频精品视频| 国产这里只有精品| www亚洲欧美| 国语对白做受69| 中文字幕日韩综合av| 亚洲男子天堂网| 日韩一级裸体免费视频| 国产成人精品日本亚洲专区61| 国产精品美女免费| 奇米一区二区三区四区久久| 精品亚洲夜色av98在线观看| 成人h片在线播放免费网站| 久久人人爽国产| 久久国产精品久久久久久久久久| 91在线免费观看网站| 欧美黄色片免费观看| 国产91精品久久久久久久| 色综合久久88色综合天天看泰| 91免费精品国偷自产在线| 亚洲一区二区三区四区在线播放| 欧美精品在线免费观看| 91亚洲精品一区二区| 国产精品久久久久久久久借妻| 78m国产成人精品视频| 欧美大片在线影院| 国产日韩欧美成人| 色综合久久久久久中文网| 中文字幕亚洲在线| 亚洲区免费影片| 中文字幕精品av| 国产91在线播放精品91| 国产日产久久高清欧美一区| 影音先锋欧美在线资源| 91tv亚洲精品香蕉国产一区7ujn| 久久91亚洲精品中文字幕奶水| 亚洲精品成a人在线观看| 久久久久在线观看| 欧美日韩国产一区在线| 欧美亚州一区二区三区| 精品久久久久久久久久久久久久| 国产成人精品在线观看| 国产丝袜一区视频在线观看| 国产精品美女久久久久久免费| 成人在线一区二区| 久久色精品视频| 久操成人在线视频| 亚洲高清不卡av|