iterativebinarysearch.java

来自「java编程代码」· Java 代码 · 共 45 行

JAVA
45
字号

public class IterativeBinarySearch
{
    /**
	 Searches the array a for key. If key is not in the array segment, then -1 is
	 returned. Otherwise returns an index in the segment such that key == a[index].
	 Precondition: a[lowEnd] <= a[lowEnd + 1]<= ... <= a[highEnd]
	*/
	public static int search(int[] a, int lowEnd, int highEnd, int key)
	{
	    int first = lowEnd;
	    int last = highEnd;
	    int mid;

	    boolean found = false; //so far
	    int result = 0; //to keep compiler happy

	    while ( (first <= last) && !(found) )
	    {
	        mid = (first + last)/2;

	        if (key == a[mid])
	        {
	            found = true;
	            result = mid;
	        }
	        else if (key < a[mid])
	        {
	            last = mid - 1;
	        }
	        else if (key > a[mid])
	        {
	            first = mid + 1;
	        }
	    }

	    if (first > last)
	        result = -1;

	    return result;
	}


}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?