33. 搜索旋转排序数组

2021-06-07 06:02

阅读:472

标签:size   排序数组   ret   相同   algorithm   target   排列   函数   names   

整数数组 nums 按升序排列,数组中的值 互不相同 。

在传递给函数之前,nums 在预先未知的某个下标 k(0

给你 旋转后 的数组 nums 和一个整数 target ,如果 nums 中存在这个目标值 target ,则返回它的下标,否则返回 -1 。

 

示例 1:

输入:nums = [4,5,6,7,0,1,2], target = 0
输出:4
示例 2:

输入:nums = [4,5,6,7,0,1,2], target = 3
输出:-1
示例 3:

输入:nums = [1], target = 0
输出:-1

 

 

#include
#include
#include
#include
#include
using namespace std;
/*
二分搜索法
关键在于获得了中间数后,判断下面要搜索左半段还是右半段,
可以得出出规律,如果中间的数小于最右边的数,则右半段是有序的,
若中间数大于最右边数,则左半段是有序的,
我们只要在有序的半段里用首尾两个数组来判断目标值是否在这一区域内,
这样就可以确定目标是否存在
例如:
第一个和最后一个比较
比第一大,比第二小就在中间

*/
class Solution {
public:
	int search(vector& nums, int target) 
	{
		int left = 0, right = nums.size() - 1;
		while (left = target)
				{
					left = mid + 1;
				}	
				else
				{
					right = mid - 1;
				}
					
			}
			else //中间比右边大情况
			{
				if (nums[left]  target)
				{
					right = mid - 1;
				}
				else
				{
					left = mid + 1;
				}
			}
		}
		return -1;
	}
};

int main()
{
	int a[1000];
	int x;
	int i = 0;
	vector vec;
	int target;
	while (cin >> a[i])
	{

		vec.push_back(a[i]);
		i++;//注意这里i++对输出结果的影响
		x = cin.get();
		if (x == ‘\n‘)
			break;

	}
	cin >> target;
	int ans = Solution().search(vec, target);
	cout 

  

33. 搜索旋转排序数组

标签:size   排序数组   ret   相同   algorithm   target   排列   函数   names   

原文地址:https://www.cnblogs.com/277223178dudu/p/14855575.html


评论


亲,登录后才可以留言!