
No.3ベストアンサー
- 回答日時:
Perl 5.10から正規表現に(?PARNO)という再帰する構文が加わりました。
その説明文に、まさに括弧対応の正規表現の例文があります。
http://fleur.hio.jp/perldoc/mix/pod/perl5100delt …
これをそのまま流用すれば、以下のようなコードが書けます。
my @expressions = qw{
(X1+X2)+X3
((X1+X2)+X3
((X1+X2))+X3
)(X1+X2)+X3
};
for my $exp (@expressions) {
print "$exp -> ", has_balanced_brackets($exp) ? 'OK' : 'NG', "\n";
}
sub has_balanced_brackets {
my $exp = shift;
my $re = qr{
^[^()]* # start of line
( # start capture buffer 1
\( # match an opening round bracket
(?: # match one of:
(?> # don't backtrack over the inside of this group
[^()]+ # one or more non round brackets
) # end non backtracking group
| # ... or ...
(?1) # recurse to bracket 1 and try it again
)* # 0 or more times.
\) # match a closing round bracket
) # end capture buffer one
}x;
$exp =~ $re ? 1 : return;
}
あるいは、文字列の先頭から1文字ずつ括弧を探し、開き括弧と閉じ括弧の数が同じかをチェックする方法はどうでしょうか?
とりあえず、質問者さん提示の例ではうまく動作しているようです。
sub has_balanced_brackets {
my $exp = shift;
my $bracket_count = 0;
for my $pos ( 0 .. length($exp)-1 ) {
my $char = substr $exp, $pos, 1;
if ( $char eq '(' ) { $bracket_count++ }
elsif ( $char eq ')' ) { $bracket_count-- }
last if $bracket_count < 0;
}
$bracket_count == 0 ? 1 : return;
}
No.2
- 回答日時:
CPU負荷(処理時間)を気にするとかなり難しいテーマになます。
「\(」や "" で囲まれた括弧は括弧で無いなんていう規則を付けても、やはり難しいテーマになります。
そうで無ければ、例えば、最も内側の () の組を可能な限り繰り返し削除した結果に 「(」か「)」を含めば NG 無ければ OK とすれば良いです。
最も内側の () の組を 1個削除するのは s/\([^\(\)]*\)//s で良いでしょう。 これをヒントにやってみてください。
禁止事項である課題の丸投げの疑いがあるので、完成コードは書きません。 追加質問は、どこまでできていて何が分らないのかを詳しく書いてください。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
perlをバージョンアップしたら...
-
openした後、closeしないでプロ...
-
3から100までの素数を配列に入...
-
Perlについて教えてください
-
perl の open について教えてく...
-
Perl言語について。
-
ファイルをディレクトリ分配の...
-
アルファベットに付いて質問し...
-
#!/usr/bin/perlで書きだしたCG...
-
Perlのエラーについてご教授く...
-
perlのflock関数でロックをかけ...
-
AI sisterとは、偽物の人ですか?
-
bashスクリプト
-
ファイルアイコンの左下に緑の□...
-
perlプログラミング 空白行削除
-
perlでリテラル値はメモリにど...
-
perlで2次元配列をサブルーチ...
-
Perlで時間の計算
-
perlについて
-
perlのrequireの動き方について...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
perl 正規表現でエラー
-
演算子と括弧
-
Perlでの改造方法
-
if等判定文での定数、変数の記...
-
msgboxに何故括弧がないの!
-
ある書籍で、見つけました、per...
-
型を調べる
-
perl tr での変数の使い方
-
日本語での正規表現について
-
例外処理のフローチャートの記...
-
「デバイスは PRN を初期化でき...
-
Excel VBAでリンク切れをチェッ...
-
エクセルVBAでシートモジュール...
-
VBでグローバル変数を宣言するには
-
Excel VBAで、ユーザーフォー...
-
ユーザー定義関数に#NAME?が返...
-
Excel VBAで、ユーザーフォーム...
-
Excel VBA 定義されたプロージ...
-
vba userFormのSubを標準モジュ...
-
標準モジュールを削除したい。(...
おすすめ情報