This article is participating in the nuggets team number online activity, click to see the dachang spring recruiting positions

1. Title Description

Problem description

Use recursive functions to find binary array elements. Add: require the given array to define int data[200]; for (i=0; i<200; I++) data [I] = I + 4 * 6;

Input format

Enter an integer to look for (it must be in the array data).

The output format

The index of the integer in the array.

The sample input

An example of an input that satisfies the problem. Case 1: 262 cases 2: 438 cases 3: 774

Sample output

Output corresponding to the sample input above. Example 1:64 cases 2: 108 cases 3: 192

Data size and conventions

The range of each number in the input data. The input data must meet the requirements of 4* I +6, I = 0,1,2,3… , 198199.

Resource constraints

Time limit: 1.0s Memory limit: 256.0MB

Second, train of thought analysis

I was not binary search, and then directly according to the characters of data input and output, such as a law Spent half an hour later learned the binary search, use dichotomy wrote back two code, for the first time in the program realization of binary search, the wheel test 😁 binary search ideas need implementation in orderly sequence, first compare an element and the sequence of elements, If it is larger than the middle, it is compared with the middle of the second half, and vice versa, it is compared with the middle of the first half, and in short, it is compared with the middle data until it is equal

AC code

Method 1: direct solution

#include<bits/stdc++.h>
using namespace std;
int main()
{
	int n;
	cin>>n;
	cout<<(n-6) /4;
	return 0; 
}
Copy the code

Method 2: binary search

#include<bits/stdc++.h>
using namespace std;
int Binsearch(int data[],int low,int high,int key)
{
	while(low<=high)
	{
		int mid=(low+high)/2;
		if(data[mid]==key) return mid;
		else if(data[mid]>key)
				high=mid-1;
			 else low=mid+1;
	}
}
int main()
{
	int data[200],n;
	for(int i=0; i<200; i++) data[i]=4*i+6;
	cin>>n;
	cout<<Binsearch(data,0.199,n);
	return 0;
}
Copy the code

Method 3: binary search recursive version

#include<bits/stdc++.h>
using namespace std;
int Binsearch(int *data,int low,int high,int key)
{
	if(low<=high)
	{
		int mid=(low+high)/2;
		if(data[mid]==key) return mid;
		else if(data[mid]>key)
				return Binsearch(data,low,mid-1,key);
			 else return Binsearch(data,mid+1,high,key);
	}
}
int main()
{
	int data[200],n;
	for(int i=0; i<200; i++) data[i]=4*i+6;
	cin>>n;
	cout<<Binsearch(data,0.199,n);
	return 0;
}
Copy the code

Four,

Binary search is a simple algorithm, but want to fully master binary search or not simple insist on learning, every day from the algorithm a little closer 😃