Balanced Brackets

Take an input string with X opening brackets [ and Y closing brackets ], in a random order.

Determine if the generated string of brackets is balanced, that is it consists of pairs of opening/closing brackets in the correct order with no matched opening and closing pairs.

The kata has been structured to be simple, yet loosely guided. You will need to make decisions just like you were writing code for production.

The examples are not meant to guide your implementation, they are there merely to guide you.

Do not worry about input other than brackets and empty string.


(empty) “”
[] OK
[][] OK
[[]] OK
[[[][]]] OK
][][ FAIL
[][]][ FAIL


Start off returning string.empty as the default condition. This will allow you properly work the red-green-refactor cycle.


You can find all language solutions here Balanced Brackets Solutions
Or you can select a specific language below.