亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

ブール式の解析

Oct 21, 2024 am 06:08 AM

Parsing A Boolean Expression

1106。ブール式の解析

難易度: 難しい

トピック: 文字列、スタック、再帰

ブール式は、true または false に評価される式です。次のいずれかの形狀になります:

  • true と評価される 't'。
  • false と評価される 'f'。
  • '!(subExpr)' は、內部式 subExpr.論理 NOT
  • として評価されます。
  • '&(subExpr1, subExpr2, ..., subExprn)' は、內部の 論理 AND として評価されます。式 subExpr1、subExpr2、...、subExprn ここで、n >= 1.
  • '|(subExpr1, subExpr2, ..., subExprn)' は、內部の 論理 OR として評価されます。式 subExpr1、subExpr2、...、subExprn ここで、n >= 1.

ブール式を表す文字列式を指定すると、その式の評価を返します。

指定された式が有効であり、指定されたルールに従っていることが保証されます。

例 1:

  • 入力: 式 = "&(|(f))"
  • 出力: false
  • 説明:
    • まず、 |(f) --> を評価します。 f.式は「&(f)」になりました。
    • 次に、&(f) --> を評価します。 f.式は「f」になりました。
    • 最後に false を返します。

例 2:

  • 入力: 式 = "|(f,f,f,t)"
  • 出力: true
  • 説明: (false OR false OR false OR true) の評価は true です。

例 3:

  • 入力: 式 = "!(&(f,t))"
  • 出力: true
  • 説明:
    • まず、&(f,t) --> を評価します。 (偽 AND 真) --> false --> f.式は「!(f)」になりました。
    • 次に、!(f) --> を評価します。 false ではありません -->真実。 true を返します。

制約:

  • 1 4
  • expression[i] は、「(」、「)」、「&」、「|」、「!」、「t」、「f」、「,」のいずれかの文字です。

ヒント:

  1. ヘルパー関數「parse_or」、「parse_and」、「parse_not」を呼び出す関數「parse」を作成します。

解決策:

ソリューションを、さまざまなタイプの式の解析と評価を処理する小さな関數 (parse_or、parse_and、parse_not)、および式の解析を再帰的に処理するメインの解析関數に分割します。スタックを使用してネストされた式を追跡し、段階的に評価します。

アプローチ:

  1. 解析と再帰:

    • ネストされた括弧が見つかった場合は、スタックを使用して式を追跡します。
    • 文字を順番に処理し、ネストされた評価のスタックを管理します。
    • 右括弧 ) が見つかった場合は、式の最後のセットを抽出し、論理演算 (&、|、または !) を適用します。
  2. ヘルパー関數:

    • parse_or: 少なくとも 1 つの部分式が true の場合に true を返すことによって |(expr1, expr2, ..., exprN) を評価します。
    • parse_and: すべての部分式が true の場合にのみ true を返すことによって &(expr1, expr2, ..., exprN) を評価します。
    • parse_not: 部分式の逆を返すことによって !(expr) を評価します。
  3. 式の処理:

    • t や f のような単一の文字は、直接 true と false に変換されます。
    • 演算 (&、|、!) が発生すると、內部式はそれぞれのルールに基づいて評価されます。

このソリューションを PHP で実裝してみましょう: 1106。ブール式の解析

<?php
/**
 * @param String $expression
 * @return Boolean
 */
function parseBooleanExpression($expression) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

/**
 * the logical AND
 * 
 * @param $subExpr
 * @return bool
 */
function parse_and($subExpr) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

/**
 * the logical OR
 * 
 * @param $subExpr
 * @return bool
 */
function parse_or($subExpr) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}
/**
 * the logical NOT
 * 
 * @param $subExpr
 * @return bool
 */
function parse_not($subExpr) {
    // subExpr contains only one element for NOT operation
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

// Test cases
echo parseBooleanExpression("&(|(f))") ? "true" : "false"; // Output: false
echo "\n";
echo parseBooleanExpression("|(f,f,f,t)") ? "true" : "false"; // Output: true
echo "\n";
echo parseBooleanExpression("!(&(f,t))") ? "true" : "false"; // Output: true
?>

説明:

  • メイン関數 (parseBooleanExpression):

    • 式を反復処理し、文字をスタックにプッシュします。
    • ) に遭遇すると、括弧內のすべての要素を収集し、演算 (&、|、!) に基づいて評価します。
    • 結果を 't' (true) または 'f' (false) に変換し、スタックにプッシュします。
  • ヘルパー関數:

    • parse_and: すべての部分式が 't' (true) の場合、true を返します。
    • parse_or: 部分式が 't' の場合は true を返します。
    • parse_not: 単一の部分式のブール値を反転します。

チュートリアルの例:

  1. 入力: "&(|(f))"

    • スタック処理:
      • &, (, |, (, f, ), ) → 內部式 |(f) は f に評価されます。
      • 結果は &(f) となり、f と評価されます。
    • 出力: false。
  2. 入力: "|(f,f,f,t)"

    • | を評価します。手術:
      • 「t」を 1 つ見つけると、true と評価されます。
    • 出力: true。
  3. 入力: "!(&(f,t))"

    • スタック処理:
      • !, (, &, (, f, ,, t, ), ) → &(f,t) は f に評価されます。
      • !(f) は true と評価されます。
    • 出力: true。

複雑:

  • 時間計算量: O(N)、N は式の長さです。各文字の処理回數は限られています。
  • 空間の複雑さ: O(N)、ネストされた式を追跡するために使用されるスタックが原因です。

このソリューションは制約に適しており、入力サイズを効果的に処理できるはずです。

連絡先リンク

このシリーズが役立つと思われた場合は、GitHub で リポジトリ にスターを付けるか、お気に入りのソーシャル ネットワークで投稿を共有することを検討してください。あなたのサポートは私にとって大きな意味を持ちます!

このような役立つコンテンツがさらに必要な場合は、お気軽にフォローしてください:

  • LinkedIn
  • GitHub

以上がブール式の解析の詳細內容です。詳細については、PHP 中國語 Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當する法的責任を負いません。盜作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫像を無料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード寫真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

寫真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中國語版

SublimeText3 中國語版

中國語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

PHP変數スコープは説明されています PHP変數スコープは説明されています Jul 17, 2025 am 04:16 AM

PHP変數スコープの一般的な問題とソリューションには次のものが含まれます。1。グローバル変數は関數內でアクセスできず、グローバルキーワードまたはパラメーターを使用して渡す必要があります。 2。靜的変數は靜的で宣言され、1回のみ初期化され、値は複數の呼び出し間で維持されます。 3. $ _GETや$ _POSTなどのハイパーグローバル変數は、任意の範囲で直接使用できますが、安全なフィルタリングに注意を払う必要があります。 4.匿名関數は、使用キーワードを使用して親スコープ変數を導入する必要があり、外部変數を変更する場合は、參照を渡す必要があります。これらのルールを習得すると、エラーを回避し、コードの安定性が向上するのに役立ちます。

ファイルアップロードをPHPで安全に処理する方法は? ファイルアップロードをPHPで安全に処理する方法は? Jul 08, 2025 am 02:37 AM

PHPファイルのアップロードを安全に処理するには、ソースとタイプを確認し、ファイル名とパスを制御し、サーバー制限を設定し、メディアファイルを2回プロセスする必要があります。 1.トークンを介してCSRFを防ぐためにアップロードソースを確認し、ホワイトリストコントロールを使用してFINFO_FILEを介して実際のMIMEタイプを検出します。 2。ファイルをランダムな文字列に変更し、検出タイプに従って非WEBディレクトリに保存する拡張機能を決定します。 3。PHP構成は、アップロードサイズを制限し、一時的なディレクトリnginx/apacheはアップロードディレクトリへのアクセスを禁止します。 4. GDライブラリは寫真を再利用して、潛在的な悪意のあるデータをクリアします。

PHPでコードをコメントします PHPでコードをコメントします Jul 18, 2025 am 04:57 AM

PHPコメントコードには3つの一般的な方法があります。1。//#を使用して1行のコードをブロックすると、//を使用することをお勧めします。 2。使用/.../複數の行でコードブロックをラップするには、ネストすることはできませんが交差することができます。 3. / if(){}を使用するなどの組み合わせスキルコメントロジックブロックを制御するか、エディターショートカットキーで効率を改善するには、シンボルを閉じることに注意を払い、使用時にネストを避ける必要があります。

発電機はPHPでどのように機能しますか? 発電機はPHPでどのように機能しますか? Jul 11, 2025 am 03:12 AM

ageneratorinphpisamemory-efficientwaytoateate-overdeatatasetasetasetasetsinging valueseintimeintimeturningthemallatonce.1.generatorsususedeywordproducevaluesedemand、memoryusage.2を還元すること。2

PHPコメントを書くためのヒント PHPコメントを書くためのヒント Jul 18, 2025 am 04:51 AM

PHPコメントを書くための鍵は、目的と仕様を明確にすることです。コメントは、「何が行われたのか」ではなく「なぜ」を説明する必要があり、冗長性や単純さを避けてください。 1.読みやすさとツールの互換性を向上させるために、クラスおよびメソッドの説明にdocblock(/*/)などの統合形式を使用します。 2。JSジャンプを手動で出力する必要がある理由など、ロジックの背後にある理由を強調します。 3.複雑なコードの前に概要説明を追加し、手順でプロセスを説明し、全體的なアイデアを理解するのに役立ちます。 4. TodoとFixmeを合理的に使用して、To Doアイテムと問題をマークして、その後の追跡とコラボレーションを促進します。優(yōu)れた注釈は、通信コストを削減し、コードメンテナンスの効率を向上させることができます。

クイックPHPインストールチュートリアル クイックPHPインストールチュートリアル Jul 18, 2025 am 04:52 AM

to installphpquickly、usexampponwindowsorhomebrewonmacos.1.onwindows、downloadandinstallxampp、selectcomponents、startapache、andplacefilesinhtdocs.2

PHPのインデックスごとに文字列內の文字にアクセスする方法 PHPのインデックスごとに文字列內の文字にアクセスする方法 Jul 12, 2025 am 03:15 AM

PHPでは、四角い括弧または巻き毛裝具を使用して文字列固有のインデックス文字を取得できますが、正方形のブラケットをお勧めします。インデックスは0から始まり、範囲外のアクセスはnull値を返し、値を割り當てることができません。 MB_SUBSTRは、マルチバイト文字を処理するために必要です。例:$ str = "hello"; echo $ str [0];出力h; MB_Substr($ str、1,1)などの漢字は、正しい結果を得る必要があります。実際のアプリケーションでは、ループする前に文字列の長さをチェックする必要があり、ダイナミック文字列を有効性のために検証する必要があり、多言語プロジェクトはマルチバイトセキュリティ関數を均一に使用することをお勧めします。

PHPの學習:初心者向けガイド PHPの學習:初心者向けガイド Jul 18, 2025 am 04:54 AM

tolearnphpefctivially、startbysettingupalocalserverenvironmentusingtoolslikexamppandacodeeditorlikevscode.1)instalxamppforapa Che、mysql、andphp.2)useocodeeditorforsyntaxsupport.3)testyoursetup withasimplephpfile.next、Learnpbasicsincludingvariables、ech

See all articles