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

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

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

2019-11-10 20:12:20
字體:
來源:轉載
供稿:網友
#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
欧洲精品在线视频| 久久人人爽人人爽人人片亚洲| 91精品久久久久久久| 中文字幕亚洲在线| 高清欧美性猛交xxxx黑人猛交| 色悠悠国产精品| 亚洲成人在线网| 国产成人福利视频| 国产性猛交xxxx免费看久久| 久久精品国产电影| 成人午夜激情免费视频| 丝袜美腿亚洲一区二区| 亚洲va欧美va国产综合剧情| 日韩久久精品成人| 日韩av在线最新| 亚洲三级av在线| 亚洲va欧美va国产综合久久| 日韩精品在线免费| 少妇久久久久久| 久久久女女女女999久久| 91精品在线观看视频| 亚洲欧洲在线免费| 岛国视频午夜一区免费在线观看| 亚洲一区二区三区在线视频| 成人在线视频福利| 国产精品视频免费在线观看| 精品丝袜一区二区三区| 欧美日韩中文字幕在线| 亚洲第一网中文字幕| 欧美一二三视频| 亚洲精品国产精品久久清纯直播| 国产精品一区久久久| 国产ts一区二区| 国产精品极品尤物在线观看| 久久精品99久久香蕉国产色戒| 欧美日在线观看| 这里只有精品视频在线| 欧美成人一区在线| 亚洲成人av片在线观看| 久久久久久高潮国产精品视| 日韩精品在线第一页| 性色av一区二区三区红粉影视| 国产精品69精品一区二区三区| 91亚洲精品久久久久久久久久久久| 亚洲福利视频专区| 国产亚洲a∨片在线观看| 国语自产在线不卡| 国内久久久精品| 国产亚洲一区二区在线| 久久全国免费视频| 91黄色8090| 日韩动漫免费观看电视剧高清| 欧美自拍视频在线观看| 亚洲欧美中文另类| 亚洲综合色激情五月| 久久夜色精品国产亚洲aⅴ| 国产日韩在线观看av| 国产成人高潮免费观看精品| 欧美成人精品xxx| 日本一欧美一欧美一亚洲视频| 国产精品av免费在线观看| 久久精品99久久香蕉国产色戒| 欧美午夜激情视频| 久久影视电视剧免费网站清宫辞电视| 日韩一区二区三区在线播放| 久久综合伊人77777尤物| 日韩电视剧在线观看免费网站| 亚洲激情视频在线| 欧美激情免费观看| 欧美福利视频网站| 色综合亚洲精品激情狠狠| 日韩欧美在线免费| 91精品视频在线免费观看| 2019最新中文字幕| 欧美黄色片视频| 九九热这里只有在线精品视| 国产亚洲日本欧美韩国| 精品久久久久久久久国产字幕| 成人a在线视频| 日韩成人激情影院| 欧美刺激性大交免费视频| 亚洲 日韩 国产第一| 久久久中文字幕| 欧美—级高清免费播放| 国产精品69久久| 久久久久久伊人| 久久91亚洲精品中文字幕奶水| 超碰97人人做人人爱少妇| 欧美大肥婆大肥bbbbb| 精品久久国产精品| 国内精品美女av在线播放| 欧美日韩免费网站| 精品动漫一区二区三区| 欧美成人免费va影院高清| 久久国产精品久久国产精品| 欧美激情高清视频| 国产成人中文字幕| 日韩二区三区在线| 日韩欧美亚洲成人| 日韩中文字幕av| 欧美香蕉大胸在线视频观看| 亚洲三级av在线| 国产精品视频免费在线| 亚洲片在线资源| 国产精品成人一区二区三区吃奶| 91夜夜揉人人捏人人添红杏| 国产精品你懂得| 国产亚洲a∨片在线观看| 欧美国产乱视频| 一区国产精品视频| 亚洲精品福利在线观看| 欧美日韩在线观看视频小说| 国产欧美日韩综合精品| 亚洲国产精彩中文乱码av在线播放| 精品人伦一区二区三区蜜桃免费| 国产精品久久久久久久一区探花| 日本午夜在线亚洲.国产| 国产婷婷色综合av蜜臀av| 国产精品丝袜一区二区三区| 亚洲深夜福利网站| 国内精品国产三级国产在线专| 中日韩美女免费视频网站在线观看| 亚洲成人a级网| 色综合天天狠天天透天天伊人| xvideos亚洲人网站| 日本欧美爱爱爱| 亚洲国产高清高潮精品美女| 欧美性极品少妇精品网站| 久久人人爽人人爽人人片亚洲| 91久久久久久久| 国产日韩中文在线| 国产精品日韩在线观看| 亚洲精品久久久久国产| 日韩久久免费视频| 国产亚洲欧洲高清一区| 日韩欧美在线免费| 久久影视三级福利片| 日韩电视剧在线观看免费网站| 亚洲欧美中文日韩在线v日本| 成人黄色影片在线| 美女视频黄免费的亚洲男人天堂| 欧美精品一区二区三区国产精品| 伊人伊成久久人综合网站| 欧美激情一区二区三级高清视频| 青青久久av北条麻妃黑人| 欧美日韩免费区域视频在线观看| 国产精品久久久久久久久男| 欧美成人中文字幕在线| 国产精品入口免费视频一| 91久久综合亚洲鲁鲁五月天| 色综久久综合桃花网| 日韩av在线最新| 国产精品久久在线观看| 亚洲在线观看视频| 亚洲欧洲日韩国产| 日韩成人性视频| 久久综合伊人77777蜜臀| 国产精品久久久久免费a∨| 亚洲精品第一页| 国产精品对白刺激| 亚洲在线免费视频| 久久福利视频导航| 欧美日韩另类字幕中文| 亚洲欧美日韩中文在线制服|