What is the Sherwood binary search algorithm in Java? -


I made my final decision on Java programming on Monday and passed it. I got a hard copy of the grade today and my instructor said that I should have used Sherwood binary search algorithms instead of regular binary search. Does anyone have a template for this algorithm? I have tried to search the web for this, but this does not mean just a copy of a real template or copy, so I can run it.

Thank you Necromancer I had to do this work and see why he wants it.

Sherwood Algorithm is a modified version of standard binary search. Search algorithms always have the best case scenario and the worst case scenario. When binary search is performed then there are always some places, which need to be failed to check. This number of unsuccessful investigations will vary greatly depending on the number of elements you are looking for.

The argument due to these failures is due to the original description of a binary search:

medium = (first + last) / 2;

The main statement behind the Sherwood algorithm is that the standard structure with Sherwood algorithms is replaced by the concept of randomness:

middle = first + rand.exit (last - first + 1 );

If you were searching a list of 1000 elements with Sherwood, the algorithm and it raised it as an element of 250. The price you're looking for can be & lt; Instead of the 250th element, 75 percent elements in the list will be left instead of only 50 percent. At the same time, the value can be higher than the 250th element and only 25 percent of the elements will be discarded in the list.

This concept is that Sherwood algorithms will reduce the time of the worst situation and still the best case time increase.

It is not that it is better than binary search, but instead showing it another way to accomplish it. I believe that there was reason behind my professor's meaning because in his class he likes to see us out of the box and see appearing in many ways for a solution. In the case of blocking a path you should always have more than one path.

  public static zero sherwoodSearch (int [] array, int value) {int first, last, middle, position, count; Found boolean; // Set the base values ​​first = 0; Last = array.length-1; Condition = -1; Found = false; Calculation = 1; Random rand = new random (); // When searching for value (! Found & amp; first & lt; = last) {count ++; Middle = first + rand.nextInt (last - first + 1); If (array [middle] == value) {found = true; Position = mediocre; } And if (array [middle]> gt; value) = the last -1; And first = medium + 1; If (first & lt; = last) {System.out.println ("Number Array was found in Subscription"); System.out.println ("Sherwood Search" + Calculation + "Number Found After Comparison"); } Else System.out.println ("Sorry, the number is not in this array." Sherwood Search "+ count + comparison".);}}    

Comments

Popular posts from this blog

ios - Adding an SKSpriteNode to SKScene from a child SKSpriteNode -

Matlab transpose a table vector -

c# - Textbox not clickable but editable -