Go Premium for a chance to win a PS4. Enter to Win

x
?
Solved

How to analyze an efficient algorithm?

Posted on 2008-06-16
7
Medium Priority
?
1,379 Views
Last Modified: 2008-08-28
Bob has a set A of n nuts and a set B of n bolts, such that each nut in A has a unique matching bolt in B.
Unfortunately, the nuts in A all look the same, and the bolts in B all look the same as well. The only kind of a comparison that Bob can make is to take a nut-bolt pair (a,b) such that a is in B, and test it to see if the threads of a are larger, smaller, or a perfect match with the threads of b. Describe and analyze an efficient algorithm for Bob to match up all of his nuts and bolts.
0
Comment
Question by:secondcup
7 Comments
 
LVL 31

Accepted Solution

by:
Frosty555 earned 672 total points
ID: 21795552
Well, the rigorous solution is to try every nut with every bolt, and use the ones that work, ignoring the extra information you have of knowing whether a nut is too small or too large for the bolt.

That would run in O(N^2) time. So when the question says "describe an efficient algorithm", it wants something better than the obvious.
0
 
LVL 74

Assisted Solution

by:sdstuber
sdstuber earned 664 total points
ID: 21795628
Compare bolt x with nut y.  If y is larger then put in "large" pile.  if y is smaller put in "small" pile.
continue until matching y is found.

Get bolt x2,  compare with y1.  if y1 is larger go to "small" pile and search.  dividing into small 1 and small 2.  If y1 is smaller then go to "large" pile and search, dividing into large 1 and large 2.

If not found in already searched piles, go to remainder of original pile of nuts.  again dividing into large and small.

get bolt x3,  compare to y2 and y1 to determine which of the prior semi-sorted nut piles to look through.  

continue through each bolt,  compare to previous bolt's nuts to try find smaller piles to search.  As you go through the bolts the piles should get smaller but more numerous with each being closer and closer to a full sort by size.

If you can get any kind of inter-bolt comparison or inter-nut comparison (which it sounds like you've already eliminated) then you can make it more efficient.  but if you can only compare bolts to nuts then I think semi-sorted piles is about as good as you'll get as it will let you derive a sorting that will help over a simple n^2 comparison
0
 
LVL 53

Expert Comment

by:Infinity08
ID: 21795841
Is this an assignment ? How far did you get ? What are you unsure about ?
0
 
LVL 22

Assisted Solution

by:NovaDenizen
NovaDenizen earned 664 total points
ID: 21813978
Use partitioning.  The expected performance is exactly the same as quicksort.
0
 
LVL 18

Expert Comment

by:philipjonathan
ID: 21828481
The performance can be better than O(n^2), it should be O(n log n)
0

Featured Post

Free Tool: Subnet Calculator

The subnet calculator helps you design networks by taking an IP address and network mask and returning information such as network, broadcast address, and host range.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

One of Google's most recent algorithm changes affecting local searches is entitled "The Pigeon Update." This update has dramatically enhanced search inquires for the keyword "Yelp." Google searches with the word "Yelp" included will now yield Yelp a…
Article by: Nadia
Suppose you use Uber application as a rider and you request a ride to go from one place to another. Your driver just arrived at the parking lot of your place. The only thing you know about the ride is the license plate number. How do you find your U…
I've attached the XLSM Excel spreadsheet I used in the video and also text files containing the macros used below. https://filedb.experts-exchange.com/incoming/2017/03_w12/1151775/Permutations.txt https://filedb.experts-exchange.com/incoming/201…
Look below the covers at a subform control , and the form that is inside it. Explore properties and see how easy it is to aggregate, get statistics, and synchronize results for your data. A Microsoft Access subform is used to show relevant calcul…
Suggested Courses

886 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question