Android Open Source - androidcodes Binary Search From Project Back to project page androidcodes .
License The source code is released under:
GNU General Public License
If you think the Android project androidcodes listed in this page is inappropriate, such as containing malicious code/tools or violating the copyright, please email info at java2s dot com, thanks.
Java Source Code package com.binarysearch;
public class BinarySearch {
/ * f r o m w w w . j a v a 2 s . c o m * /
private int arr[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14 };
public int binarySearch(int num) {
int first = 0;
int last = arr.length - 1;
int middle = (first + last) / 2;
while (first <= last) {
if (num > arr[middle]) {
first = middle + 1;
} else if (num < arr[middle]) {
last = middle - 1;
} else if (num == arr[middle]) {
return middle;
}
middle = (first + last) / 2;
}
return -1;
}
public int binarySearchRecursion(int num, int first, int last) {
if (first > last) {
return -1;
}
int middle = (first + last) / 2;
if (num > arr[middle]) {
return binarySearchRecursion(num, middle + 1, last);
} else if (num < arr[middle]) {
return binarySearchRecursion(num, first, middle - 1);
} else if (num == arr[middle]) {
return middle;
}
return -1;
}
public static void main(String[] args) {
BinarySearch b = new BinarySearch();
System.out.println(b.binarySearch(86));
System.out.println(b.binarySearchRecursion(99, 0, 13));
}
}
Java Source Code List com.app.citypediav2.Constants.java com.app.citypediav2.CustomButton.java com.app.citypediav2.CustomEditText.java com.app.citypediav2.CustomText.java com.app.citypediav2.DetailsActivity.java com.app.citypediav2.ItemListActivity.java com.app.citypediav2.ItemListAdapter.java com.app.citypediav2.ListAdapterOptions.java com.app.citypediav2.MainActivity.java com.app.citypediav2.MainApplication.java com.app.citypediav2.Options.java com.app.citypediav2.receivers.BootCompletedBroadcastReceiver.java com.app.citypediav2.receivers.ConnectionChangeReceiver.java com.app.citypediav2.services.DataLoggingService.java com.app.citypediav2.utils.AppUtils.java com.app.citypediav2.utils.ArticleTextExtractor.java com.app.citypediav2.utils.Constants.java com.app.citypediav2.utils.LogUtils.java com.app.citypediav2.utils.PrefUtils.java com.app.twitterclient.model.TwitterBackend.java com.app.twitterclient.utils.AppUtils.java com.app.twitterclient.utils.ConnectionDetector.java com.app.twitterclient.utils.ConsumerKeyConstants.java com.app.twitterclient.utils.LogUtils.java com.app.twitterclient.view.BootActivity.java com.app.twitterclient.view.HomeActivity.java com.app.twitterclient.view.NewAccountActivity.java com.app.twitterclient.view.TwitterAuthActivity.java com.binarysearch.BinarySearch.java com.citypedia.app.enities.Atms.java com.citypedia.app.enities.Cabs.java com.citypedia.app.enities.Gyms.java com.citypedia.app.enities.PetrolPumps.java com.citypedia.app.enities.PlacesToVisit.java com.citypedia.app.enities.Restaurants.java com.citypedia.app.providers.CityDB.java com.citypedia.app.providers.CityPediaProvider.java com.citypedia.app.providers.ContentDescriptor.java com.info.magazine.MainActivity.java com.java.thread.ConditionExample.java com.java.thread.DeadLock.java com.java.thread.Main.java com.java.thread.ProdConsumerProb.java com.java.thread.SampleThread.java com.java.thread.package-info.java com.lists.LinkedListImpl.java com.pract.threadpool.CustomQueue.java com.pract.threadpool.MyQueue.java com.pract.threadpool.TestThreadPoolManager.java com.pract.threadpool.ThreadPoolManager.java com.pract.threadpool.Worker.java com.queues.QueuesImpl.java com.rjil.logcollector.DeviceBroadcastReceiver.java com.rjil.logcollector.LogCollectorService.java com.rjil.logcollector.LogDumper.java com.sorting.InsertionSort.java com.sorting.package-info.java com.stacks.BracketChecker.java com.stacks.StackImpl.java com.stacks.StockSpan.java