Test your mettle at

Ever wanted to see how your skills match up against other programmers? has programming tournaments that pit you against other coders and could even land you another job.

Ever wanted to challenge the know-it-all in the next cube to a WWF-style, no-holds-barred, caged Texas-grudge match so you could knock him down a couple of notches? If so, might be just what you’re looking for. And it just might help you get a better job, to boot.

You may have heard of TopCoder by virtue of its recently concluded college programming competition, which netted the winner, an MIT student, a cool $100,000 prize. But college competitions aren’t the only thing at TopCoder. The site also sponsors regular programming “tournaments” that registered members can compete in for real cash prizes.

Are you ready to rumble?
At any given time, there are several programming competitions, or tournaments, taking place on TopCoder. The tournaments may involve hundreds of contestants broken into small groups or “rooms” and consist of multiple coding rounds. In each round, participants must write Java code that solves a particular set of algorithmic problems and then subject their solutions to review by other competitors and system testing by TopCoder’s tournament server.

Each coding round is timed. Coders have about one hour to solve three programming problems of varying degrees of difficulty: one easy, one medium, and one hard. Participants are awarded points for each completed problem based on the proportion of the round’s time they spent on the problem. Of course, difficult problems are worth more points than easy problems but take more time to complete.

Each problem specifies a method declaration, what the code is supposed to accomplish, the conditions that will be met before a call to the participant’s code is made, and a set of test cases. These are not simple business problems by any means, being more akin to the brainteaser algorithm problems programming professors like to throw at their students. (Remember the Towers of Hanoi?) As an example, one of the medium difficulty problems I saw when I visited the TopCoder site involved creating an algorithm to trace from top to bottom through a triangle-shaped matrix of numbers and find the path that would result in the highest total if all numbers in the path were added together.

Participants enter their code into an editor provided by TopCoder’s competition applet. The editor window contains a clock that counts down the time remaining in the round, making for some tense moments when the clock nears zero and you still have a few lines to write. The applet also provides a compiler, lets you run your code, and has simple search/replace functionality, but that’s about it. No online help, no syntax prompting; you are on your own. To advance from the coding phase, you must submit compilable code for at least one problem.

Withstanding the challenge
At the end of the timed coding phase, contestants move on to the challenge phase, where other coders review their code for potential logic problems. If a contestant sees a problem with another contestant’s code, he or she may challenge it by supplying a set of input parameters that will break it. The TopCoder server then tests the challenged code with the challenger’s parameters. The challenger is awarded bonus points and the challenged coder loses points if the code breaks or produces an invalid result. An unsuccessful challenge results in a point loss for the challenger.

In the final phase in a round, system testing, the TopCoder server tests each contestant’s code with a predefined number of test cases. Any code that generates an incorrect result is disqualified, and its author receives no points for that submission.

The competitors with the highest scores from each tournament room may continue onto the next round with a new set of problems to solve. The advancement process varies with the tournament, but the winner is the coder with the highest point total at the end of the tournament. The top three scorers usually receive cash prizes, so there’s definitely an incentive, beyond simple pride, to compete.

So where’s the catch?
TopCoder is free to join and doesn’t charge entry fees for the various tournaments. Its stated mission is to increase the perceived value of programmers by providing an objective rating system for them. Evidently, the company hopes to make money from contest sponsors and by providing the profiles and contest ratings of its members to subscriber companies that are looking for new development talent.

Indeed, if you’ve ever set up a profile on an online job service before, registering on TopCoder will seem very familiar: Rate yourself on these skills, what’s your educational background, will you relocate, and so on. Fortunately, TopCoder comes out and asks whether you’re looking for work instead of automatically assuming that you are. So you’re free to join and compete in a few tournaments, or just look around, without inciting hordes of recruiters to descend upon you.

There’s no word yet on whether this rather novel recruiting system works. (TopCoder just launched in March 2001.) Of course, even if it doesn’t really land anyone a job, TopCoder offers an interesting diversion and a chance to hone your Java skills, and it provides some value simply by feeding the competitive urges of the propeller-head in us all.

Editor's Picks