![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?5a7ff87)
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で質問しましょう!
似たような質問が見つかりました
- 数学 線形代数の対称行列についての問題がわからないです。 2 2023/01/08 14:59
- 数学 場合の数、確率 45 (浜松医科大学) 1 2023/07/29 13:52
- 数学 ハイネボレルの被覆定理、内田伏一著 「集合と位相」定理22.1 1 2022/07/07 10:49
- 数学 数学(ベクトル) 単位ベクトルの一次結合で一般の空間ベクトルは表せる という式なのですがなぜ 「x1 3 2023/04/10 01:24
- 数学 x1+3x2+2x3=4 2x1+x2-3x3=2 -5x1+5x2+18x3=a 次の連立1次方程 2 2023/07/02 03:15
- 数学 「FFTの基本は、DFTはサンプル数Nが偶数なら 2つのDFTに分解できるということ。 分解するとD 3 2022/03/31 21:01
- 物理学 あのこれは、間違いと 3 2022/11/13 12:22
- 数学 存在記号と「または」 5 2022/10/02 19:03
- 物理学 二重障壁の計算 1 2023/03/05 16:49
- 憲法・法令通則 どなたかお願いします。憲法の問題です。 A社では、毎年度従業員の勤務に対する評定を10段階で評価し、 5 2022/12/02 23:46
関連するカテゴリからQ&Aを探す
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Perlで時間の計算
-
テキストファイルで提出とは?
-
perlプログラミング 空白行削除
-
Perlで特定文字列から特定文字...
-
openした後、closeしないでプロ...
-
PerlでUTF-8のファイルの文字列...
-
bashスクリプト
-
arduino の割り込み処理について
-
Perl テキスト 列検索
-
アルファベットに付いて質問し...
-
perlで複数のファイルの処理に...
-
#!/usr/bin/perlで書きだしたCG...
-
Perlのエラーについてご教授く...
-
perlのflock関数でロックをかけ...
-
AI sisterとは、偽物の人ですか?
-
ファイルアイコンの左下に緑の□...
-
perlでリテラル値はメモリにど...
-
perlで2次元配列をサブルーチ...
-
perlについて
-
perlのrequireの動き方について...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
型を調べる
-
perl 正規表現でエラー
-
perl tr での変数の使い方
-
perlのif文で・・・・・
-
例外処理のフローチャートの記...
-
Excel VBAでリンク切れをチェッ...
-
エクセルVBAでシートモジュール...
-
「デバイスは PRN を初期化でき...
-
VBAで別モジュールへの変数の受...
-
VBでグローバル変数を宣言するには
-
Excel VBA 『Call』で呼び出す...
-
Excel VBA 定義されたプロージ...
-
VBA This Workbookモジュール...
-
ユーザー定義関数に#NAME?が返...
-
VBSがコンパイルエラーになりま...
-
Excel VBAで、ユーザーフォーム...
-
ArduinoのジャイロモジュールMP...
-
LCD ディスプレイを Raspberry ...
-
グラフのX,Y座標を取得したい
-
'Range'メソッドは失敗しました
おすすめ情報