function isBalanced(str) {
// пары открывающих-закрывающих скобок
var br = "(){}[]";
// стек открытых скобок
var st = [];
// бежим по всей строке
for (var i = 0; i < str.length; ++i) {
// текущий символ
var ch = str[i];
// ищем символ в скобках
var ind = br.indexOf(ch);
// если скобка найдена
if (ind >= 0) {
// проверяем, какая это скобка
if (ind & 1) {
// если закрывающая скобка, проверяем стек
// стек пуст - плохо
if (!st.length) return false;
// извлекаем последнюю открытую скобку из стека
var last_br = st.pop();
// если она не соответствует закрывающей скобке - тоже плохо
if (last_br != br[ind - 1]) return false;
} else {
// открывающую скобку просто пихаем в стек
st.push(ch);
}
}
}
// если после обхода всей строки стек пуст - всё ок
return !st.length;
}
var haveSameLength = function(str, a, b){
return (str.match(a) || [] ).length === (str.match(b) || [] ).length;
};
var isBalanced = function(str){
var arr = [
[ /\(/gm, /\)/gm ], [ /\{/gm, /\}/gm ], [ /\[/gm, /\]/gm ]
], i = arr.length, isClean = true;
while( i-- && isClean ){
isClean = haveSameLength( str, arr[i][0], arr[i][1] );
}
return isClean;
};