Skip to main content

Implementation of a simple algorithm (to calculate probability)


EDIT: I've got it, thanks for all the help everyone! + Cleaned up post a little bit.



Also, this article was very helpful: http://www.codinghorror.com/blog/archives/001204.html?r=1183





Hi all,



I've been asked (as part of homework) to design a Java program that does the following:





Basically there are 3 cards:



  • Black coloured on both sides

  • Red coloured on both sides

  • Black on one side, red on the other side



Now if I take a card randomly and place it on the table. The side facing up is black. What is the probability that the other side is also black?



Implement a program using Java and try to discover the probability, the program should simulate the card trick a large number of times and should output the probability that the other side of the card is black (it does this by counting how many times the other side also black).





However I've been told that my code is wrong (algorithm wise)... apparently the answer should not be 0.50. Have I made a mistake in trying to understand the algorithm?



Can anyone point me in the right direction please? (I'm not asking you to provide me with a fully working implementation, just on how the algorithm should work).


Source: Tips4all

Comments

  1. This might not help with the algorithm, but this is how I would derive the answer myself:

    When you draw a random card and place it on the table, there are six equally probable things that could happen:


    You select the R/R card and place it red-side up.
    You select the R/R card and place the other red-side up.
    You select the B/R card and place it black-side up.
    You select the B/R card and place it red-side up.
    You select the B/B card and place it black-side up.
    You select the B/B card and place the other black-side up.


    Of these six events, 3 out of 6 result in a black-side up card on the table.

    Of these 3 events, in exactly two of them is the other side of the card black.

    Therefore the answer to the question "What is the probability that the other side is also black?" is 2/3.

    Your algorithm fails because you are only counting the black_black card coming up as a single event, when it is actually two.

    ReplyDelete
  2. Your algorithm is missing a key step: putting the card on the table. If you draw the black-red card, there is no guarantee that the black side is showing when you put it down. Add an additional step to simulate selecting randomly one of the sides of each card, then determine how many cases show a black face, and then how many of those cases have the black-black card showing.

    ReplyDelete
  3. There are six sides to the cards, and we will assume them to come up with equal probability. There are three black faces, and two of them have black on the other side. We discard all cases in which a red face is uppermost, so we're only concerned with three black faces, of equal probability.

    Therefore, the probability that the other face is black is in fact 2/3.

    ReplyDelete
  4. I think you need to account for the two possibilities of the red-black card being drawn: red-side-up and black-side-up. The sum of these probabilities will be the probability that the red-black card is drawn at all.

    ReplyDelete
  5. It may help to examine the problem that you have correctly implemented: given that you have randomly picked a card that is black on at least one side, what are the odds that the card is black on one side and red on the other?

    The problem that you haven't implemented correctly is: given that you are looking at a card that is black on this face, what are the odds that it is red on the other face?

    Note that there are two black cards, but three black faces.

    ReplyDelete
  6. The card with both sides red is basically (forgive the pun) a red herring -- any way it's dealt, it'll come up red and we don't need to care about it any more.

    That leaves only the red/black and the black/black card. Again, we need pay no further attention if the red/black is dealt red side up. The remaining possibilities are:red/black, black upblack/black, first side upblack/black, second side up
    Since two of those three have the other side black, the probability is two out of three.

    ReplyDelete

Post a Comment

Popular posts from this blog

Why is this Javascript much *slower* than its jQuery equivalent?

I have a HTML list of about 500 items and a "filter" box above it. I started by using jQuery to filter the list when I typed a letter (timing code added later): $('#filter').keyup( function() { var jqStart = (new Date).getTime(); var search = $(this).val().toLowerCase(); var $list = $('ul.ablist > li'); $list.each( function() { if ( $(this).text().toLowerCase().indexOf(search) === -1 ) $(this).hide(); else $(this).show(); } ); console.log('Time: ' + ((new Date).getTime() - jqStart)); } ); However, there was a couple of seconds delay after typing each letter (particularly the first letter). So I thought it may be slightly quicker if I used plain Javascript (I read recently that jQuery's each function is particularly slow). Here's my JS equivalent: document.getElementById('filter').addEventListener( 'keyup', function () { var jsStart = (new Date).getTime()...

Is it possible to have IF statement in an Echo statement in PHP

Thanks in advance. I did look at the other questions/answers that were similar and didn't find exactly what I was looking for. I'm trying to do this, am I on the right path? echo " <div id='tabs-".$match."'> <textarea id='".$match."' name='".$match."'>". if ($COLUMN_NAME === $match) { echo $FIELD_WITH_COLUMN_NAME; } else { } ."</textarea> <script type='text/javascript'> CKEDITOR.replace( '".$match."' ); </script> </div>"; I am getting the following error message in the browser: Parse error: syntax error, unexpected T_IF Please let me know if this is the right way to go about nesting an IF statement inside an echo. Thank you.