だからここに私の問題があります:
文字列のバランスをチェックする C++ プログラムを作成することになっています。これまでのところ、同じ数の ( と ) があることを確認するコードが動作しています ([ と { と同じ)。問題は、これがほとんどすべての場合に機能することですが、{、(、および [ がすべて混同されている文字列には機能しません。
例: "{ { [ ( ) ] } ( ) }" は、本来あるべきバランス (true) として返されます。ただし、「{ ( [ ] } )」は true を返しますが、そうすべきではありません。
ロジックやコードが故障したときにチェックするアイデアは何ですか?
助けてくれてありがとう!
それが役立つ場合、私のコードは次のとおりです。
bool ExpressionManager::isBalanced(string expression)
{
//remove whitespace
string edited;
for(int i = 0; i < expression.length(); i++)
{
if(expression[i] == ' ')
{
continue;
}
else
{
edited += expression[i];
}
}
expression = edited;
//set up brckets
string brackets;
for(int i = 0; i < expression.length(); i++)
{
if (expression.at(i)=='(')
{
brackets += expression.at(i);
}
if (expression.at(i)=='[')
{
brackets += expression.at(i);
}
if (expression.at(i)=='{')
{
brackets += expression.at(i);
}
if (expression.at(i)=='}')
{
brackets += expression.at(i);
}
if (expression.at(i)==']')
{
brackets += expression.at(i);
}
if (expression.at(i)==')')
{
brackets += expression.at(i);
}
}
int parenbal = 0;
int brackbal = 0;
int mustachebal = 0;
for (int i = 0; i<(brackets.size());i++)
{
if(brackets[i]=='(')
parenbal++;
if(brackets[i]=='[')
brackbal++;
if(brackets[i]=='{')
mustachebal++;
if(brackets[i]==')')
parenbal--;
if(brackets[i]==']')
brackbal--;
if(brackets[i]=='}')
mustachebal--;
}
bool isbalanced = false;
if ((mustachebal==0)&&(brackbal==0)&&(parenbal==0))
{
isbalanced = true;
}
//check for brackets mixed up with other stuff.
return isbalanced;
}