I am running a code to balance brackets in statement. I think i have gotten it correct but it is failing on one particular statement, i need to understand why?
This
You've made a very simple and completely understandable mistake. The parentheses in )(
are balanced, by your current definition. It's just that they're not balanced in the way we would usually think. After the first character, you have -1 unclosed parentheses, and then after the second characte we're back to 0, so everything is fine. If the parenthesis count ever drops below zero, the parentheses cannot possibly be balanced.
Now there are two real ways to handle this. The quick and dirty solution is to throw an exception.
case object UnbalancedException extends Exception
if (i < 0)
throw UnbalancedException
then catch it and return false in balance
.
try {
... // find() call goes in here
} catch {
case UnbalancedException => false
}
The more functional solution would be to have find
return an Option[Int]
. During the recursion, if you ever get a None
result, then return None
. Otherwise, behave as normally and return Some(n)
. If you ever encounter the case where i < 0
then return None
to indicate failure. Then in balance
, if the result is nonzero or the result is None
, return false. This can be made prettier with for
notation, but if you're just starting out then it can be very helpful to write it out by hand.