對於一個有序數組,我們通常采用二分查找的方式來定位某一元素,請編寫二分查找的算法,在數組中查找指定元素。 給定一個整數數組A及它的大小n,同時給定要查找的元素val,請返回它在數組中的位置(從0開始),若不存在該元素,返回-1。若該元素出現多次,請返回第一次出現的位置。


// ConsoleApplication10.cpp : 定義控制台應用程序的入口點。
//

#include "stdafx.h"
#include <iostream>
#include <vector>
#include <string>
using namespace std;

class BinarySearch {
public:
	int getPos(vector<int> A, int n, int val) {
		// write code here
		int beg = 0;
		int end = n-1;
		int mid = (beg + end) / 2;
		int pos = -1;
		while (beg<=end)
		{
			if (A[mid] == val)
			{
				--mid;
				while (A[mid]==val && mid>=0)
				{
					--mid;
				}
				pos = mid + 1;
				break;
			}
			else if (A[mid] < val)
			{
				beg = mid + 1;
				mid= (beg + end) / 2;
			}
			else
			{
				end = mid - 1;
				mid = (beg + end) / 2;
			}
		}
		return pos;
	}
};
int main()
{
	vector<int> A = { 3,3,5,7,9 };
	int n = 5, val = 3;
	BinarySearch bs;
	cout << bs.getPos(A, n, 3) << endl;

	return 0;
};


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM