Loading collection data...
Collections are a way for you to organize kata so that you can create your own training routines. Every collection you create is public and automatically sharable with other warriors. After you have added a few kata to a collection you and others can train on the kata contained within the collection.
Get started now by creating a new collection.
CoffeeScript translation
Java translation
It should work for random inputs too - Expected: undefined, instead got: 'Lex Luthor'
in the first round 2:2 between Lex and Drake, then 1:1 between them in the second, and in the third 2:1 in favor of Lex, why should there be a draw? Most likely I didn't understand the condition. help please.
Tip for those who are stuck in the random questions: don't mutate the array of votes. (should be mentioned in the description)
Scala translation
No example tests
This comment is hidden because it contains spoiler information about the solution
Needs random tests
Needs sample tests
This comment is hidden because it contains spoiler information about the solution
Not mentioned in the description: in order to pass the test cases, you must also exclude from the runoff any candidate who received no votes.
I'm liking this kata, but I'm running into one final problem when trying to complete it. While the description doesn't mention it, I went ahead an included checks for duplicate flags and names in the boolean flags, argument flags, and arguments. My thought, along with avoiding duplicate names in the output (which isn't too big of a deal if the associated flags are unique), was that we should avoid the situation where the input is something like "-b" and "b" is defined as both a boolean and an argument flag. In the first set of test cases, however, this situation does arise.
How should duplicate flags or names be handled?
Descriptions are very unclear and sometimes completely wrong. Even the wikipedia page does not help as there are many variations.
The only way to figure out the specific rules is adding a puts at the top of the method and working towards the expected result.
Should provide more samples cases or change the description.
Do not use "Start over." in the description. You do not start over, you keep a running tally.
Try numbering the steps so you can refer to them.
It would be good to mention how the votes are tallied after removing the bottom candidates. Maybe something like...
"After removing the bottom candidates, count all the top votes for the "new" voters list and add those votes to the previous tally. Go to step 3"
(If the first-place candidate has more than half the total votes, they win.)
"first-place" could be misunderstood, maybe reword that to...
"If a candidate has more than half the total votes, they win."
I've a couple test cases that demonstrates how this problem is insufficiently defined and needs more test cases:
For example, @hencethus and @evilscott/@Dima83 have differing solutions that pass the tests. However:
@hencethus's solution maintains tallies across iterations, disqualifying losers along the way.
@evilscott's and @Dima83's solution declares the candidate with the most first-votes to be the winner rather than the one with "more than half the total votes"