指定された条件に基づいて、最大 1 のサブシーケンスの最小ステップを決定します。
この記事の目的は、与えられた条件に基づいて最大 1 秒のサブシーケンスを決定する最小ステップを見つけるプログラムを実装することです。
ご存知のとおり、NULL で終了する文字を含む 1 次元配列を使用して文字列を定義できます。
長さ K の文字列 Str を指定します。K は常に偶数で、文字「0」、「1」、および「?」が含まれます。文字列を 2 つの別々の文字列に分割し、それぞれ Str1 と Str2 と呼びます。文字列には、Str の偶数値と奇数値の文字が含まれます。目標は、2 つの文字列 (Str1 または Str2) 内の 1 の最大数を予測するために必要な最小ステップ数を決定することです。 Str1 または Str2 の文字を 1 ステップで選択します。文字が 0 の場合は「0」、文字が 1 の場合は「1」、1 または 0 の場合は「?」を選択します。
###問題文###与えられた条件に基づいて最大 1 秒のサブシーケンスを決定するための最小ステップを見つけるプログラムを実装します
例 1
リーリー リーリーイラスト
- ステップ 1
- ここで Str[0] は「?」です。
リーリー
- ステップ 2
- ここで Str[1] は「1」です。
リーリー
- ステップ 3
- ここで Str[2] は「0」です。
リーリー
- ステップ 4
- ここで Str[3] は「?」です。
リーリー 残りのインデックスがどのような数値を選択しても、ステップ 4 の後に Str2 にはさらに 1 が含まれます。
例 2
リーリー リーリーイラスト
- ステップ 1
- ここで Str[0] は「1」です。
リーリー
- ステップ 2
- ここで Str[1] は「?」です。
リーリー
- ステップ 3
- ここで Str[2] は「0」です。
リーリー
- ステップ 4
- ここで Str[3] は「?」です。
リーリー
- ステップ 5
- ここで Str[4] は「?」です。
リーリー
- ステップ 6
- ここで Str[5] は「0」です。
リーリー
- ステップ 7
- ここで Str[6] は「1」です。
リーリー 残りのインデックスがどのような数値を選択しても、ステップ 7 の後に Str2 にはさらに 1 が含まれます。
指定された条件に基づいて最大 1 秒のサブシーケンスを決定するための最小ステップを見つけるには、次のアプローチを使用します。
以下に、この問題を解決し、与えられた条件に基づいて最大 1 秒のサブシーケンスを決定するための最小ステップを見つける方法を示します。
目標は、問題を再帰的に解決し、それぞれの選択肢を検討した後に解決策に到達することです。
「再帰」という用語は、直接 (つまり仲介者なしで) または間接的に、関数自体を呼び出すプロセスに他なりません。この同等の関数は再帰関数と言われます。さらに、再帰的アルゴリズムを使用すると、さまざまな問題を比較的簡単に解決できます。
###アルゴリズム###以下の与えられた条件に基づいて最大 1 秒のサブシーケンスを決定する最小ステップを見つけるアルゴリズム
ステップ 1
- 始めましょう
ステップ 2 - 再帰関数を定義します。
-
ステップ 3 - 文字列 Str、整数 i、整数 count1 および count2 を定義します。これらは、i までの数値をそれぞれ Str1 と Str2 に格納するために使用されます。
ステップ 4 - 整数 n1 と n2 を定義して、Str1 と Str2 に使用可能な位置を格納します
ステップ 5 - i が m に等しい場合、Str1 と Str2 の両方が完全に入力され、答えが確実に期待できるようになります。ですので、0と返信してください。
ステップ 6 - count1 が n2 と count2 の積を超える場合は、Str2 値のすべての値を選択した後でも Str1 が Str2 を超えるため、0 を返します。
- 上記の理由により、count2がn1とcount1の積を超えた場合は0を返します。
ステップ 7
- 基本インスタンスをテストした後、i が偶数または奇数に等しいことを確認します。 i が偶数の場合は Str1 がこのインデックスを選択し、そうでない場合は Str2 が選択します。
- 文字列内のアクセス可能な位置の数はパディング後に 1 位置ずつ減るため、現在パディングされている文字列に応じて n1 または n2 ずつ減ります。
- それ以外の場合は、電話をかけ、電話番号を追加して応答を取得します。
このクエリに対する応答は、最後の再帰呼び出しによって提供されます。
-
例: C プログラム これは、指定された条件に基づいて 1 秒の最大サブシーケンスを決定するための最小ステップを見つけるために上で書かれたアルゴリズムの C プログラム実装です。 リーリー ###出力### リーリー ###結論は###
同様に、与えられた条件に基づいて最大 1 のサブシーケンスを決定するための最小ステップ数を見つけることができます。 このペーパーでは、与えられた条件で最大 1 秒のサブシーケンスを決定するための最小ステップ数を取得するという課題に取り組みます。
ステップ 8
- 停止C プログラミング コードは、与えられた条件で最大 1 秒のサブシーケンスを決定する最小ステップを見つけるアルゴリズムとともにここに提供されます。
以上が指定された条件に基づいて、最大 1 のサブシーケンスの最小ステップを決定します。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック











GULCは、最小限のオーバーヘッド、積極的なインライン、およびコンパイラの最適化を優先する高性能Cライブラリです。 高周波取引や組み込みシステムなどのパフォーマンスクリティカルなアプリケーションに最適な設計では、シンプルさ、モジュールが強調されています

この記事では、c関数のリターンタイプ、基本(int、float、charなど)、派生(配列、ポインター、構造体)、およびvoid型を含む詳細を示します。 コンパイラは、関数宣言とreturnステートメントを介して返品タイプを決定し、強制します

この記事では、C関数宣言と定義、引数の合格(価値とポインターによる)、返品値、およびメモリリークやタイプの不一致などの一般的な落とし穴について説明します。 モジュール性とProviの宣言の重要性を強調しています

この記事では、文字列ケース変換のC関数について詳しく説明しています。 ctype.hのtoupper()とtolower()を使用し、文字列を介して繰り返し、ヌルターミネーターを処理することを説明しています。 ctype.hを忘れたり、文字列リテラルを変更するなどの一般的な落とし穴は

この記事では、C関数の戻り値ストレージを調べます。 通常、リターン値は通常、速度のためにレジスタに保存されます。値が大きいと、ポインターをメモリ(スタックまたはヒープ)に使用し、寿命に影響を与え、手動のメモリ管理が必要になります。直接acc

この記事では、形容詞の「個別」の多面的な使用法を分析し、その文法機能、一般的なフレーズ(例:「はっきりと異なる」とは異なる」、およびフォーマルと非公式の微妙なアプリケーションを調査します。

この記事では、C標準テンプレートライブラリ(STL)について説明し、そのコアコンポーネント(コンテナ、イテレーター、アルゴリズム、およびファンクター)に焦点を当てています。 これらが一般的なプログラミングを有効にし、コード効率を向上させ、読みやすさを改善する方法を詳述しています。

この記事では、cの効率的なSTLアルゴリズムの使用について詳しく説明しています。 データ構造の選択(ベクトル対リスト)、アルゴリズムの複雑さ分析(STD :: STD :: STD :: PARTIAL_SORTなど)、イテレーターの使用、および並列実行を強調しています。 のような一般的な落とし穴
