検索
ホームページバックエンド開発C++文字が部分文字列と同じであり、頻度の差が最大 K である最長の部分列

文字が部分文字列と同じであり、頻度の差が最大 K である最長の部分列

この問題では、連続する文字が含まれ、すべての文字の頻度の差が K を超えないようなサブシーケンスの最大長を見つけます。

出力を取得するには、指定された文字列の考えられるすべてのサブシーケンスを検索し、その中に各文字が連続して最大の頻度差で含まれているかどうかを確認する必要があります。

問題ステートメント- 小文字のアルファベット文字を含む文字列 alpha が与えられています。さらに、正の整数 K が与えられています。次の規則に従うように、指定された文字列のサブシーケンスの最大長を見つける必要があります。

  • 特定の文字はすべて連続して出現する必要があります。

  • 文字の頻度の差が K を超えることはできません。

######例###### ######入力###### リーリー ######出力###### リーリー

説明 - 「pppqrs」サブシーケンスを取得できます。最大文字頻度は 3 で、最小文字頻度は 1 です。したがって、その差は2となります。そして、すべての文字が連続して含まれます。

######入力###### リーリー ######出力###### リーリー

説明 - 「abbbc」サブシーケンスを取得できます。

######入力###### リーリー ######出力###### リーリー

説明 - 「nnnnnnn」サブシーケンスを取得できます。

方法1 このメソッドでは、再帰関数を使用して、指定された長さのすべてのサブシーケンスを検索します。さらに、サブシーケンスにすべての文字が連続して含まれているかどうかを確認する関数を定義します。マップ データ構造を使用して、最大および最小の周波数差を計算します。

###アルゴリズム###

ステップ 1 - 文字の頻度を保存する「f」マッピングを定義します。

ステップ 2 - start が一時文字列の長さに等しく、文字列の長さが 0 より大きい場合は、次の手順に従います。

ステップ 3 - 「minf」変数と「maxf」変数を初期化して、最小周波数と最大周波数を保存します。

ステップ 4 - マップをクリアし、各文字の頻度をマップに保存します。

ステップ 5 - マップ値をループし、周波数の最大値と最小値を見つけます。

ステップ 6 - 最大頻度と最小頻度の差が K 以下の場合は、文字列に連続した文字が含まれているかどうかを確認します。

ステップ 6.1

- checkForContinously() 関数で、特定の文字の最後の位置を保存する「pos」マップを定義します。

ステップ 6.2

- 文字列をトラバースします。現在のキャラクターがマップ内に存在し、キャラクターの現在位置と最後の位置の差が 1 未満の場合は、最後の位置を更新します。それ以外の場合は false を返します。

ステップ 6.3

- キャラクターが存在しない場合は、マップにキャラクターを追加します。

ステップ 6.4

- 最後に true を返します。

ステップ 7

- 文字列に連続した文字が含まれており、頻度の差が K 未満で、「maxi」の値が現在のサブシーケンスの長さより小さい場合は、「maxi」の値を更新します。 '。

ステップ 8

- 現在の文字を除外した後、再帰呼び出しを行います。

ステップ 9

- 現在の文字を一時文字列の末尾に追加します。また、更新された「tmp」文字列を使用して再帰呼び出しを実行します。 ###例### リーリー ###出力### リーリー 時間計算量 - O(N*2N)。O(N) は連続文字のチェックに使用され、O(2N) はすべてのサブシーケンスの検索に使用されます。

スペースの複雑さ - 一時的なサブシーケンスを保存するには O(N)。 簡単な方法を使用して、指定された文字列のすべてのサブシーケンスを検索します。ただし、これには非常に時間がかかります。大きな文字列の問題を解決するためにこの方法を使用することはお勧めできません。

以上が文字が部分文字列と同じであり、頻度の差が最大 K である最長の部分列の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事はtutorialspointで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。
CおよびXML:プロジェクトにデータを統合しますCおよびXML:プロジェクトにデータを統合しますMay 10, 2025 am 12:18 AM

CプロジェクトにXMLを統合することは、次の手順を通じて達成できます。1)PUGIXMLまたはTinyXMLライブラリを使用してXMLファイルを解析および生成すること、2)解析のためのDOMまたはSAXメソッドを選択、3)ネストされたノードとマルチレベルのプロパティを処理する、4)デバッグ技術と最高の慣行を使用してパフォーマンスを最適化します。

CでXMLを使用する:ライブラリとツールのガイドCでXMLを使用する:ライブラリとツールのガイドMay 09, 2025 am 12:16 AM

XMLは、特に構成ファイル、データストレージ、ネットワーク通信でデータを構成するための便利な方法を提供するため、Cで使用されます。 1)tinyxml、pugixml、rapidxmlなどの適切なライブラリを選択し、プロジェクトのニーズに従って決定します。 2)XML解析と生成の2つの方法を理解する:DOMは頻繁にアクセスと変更に適しており、SAXは大規模なファイルまたはストリーミングデータに適しています。 3)パフォーマンスを最適化する場合、TinyXMLは小さなファイルに適しています。PugixMLはメモリと速度でうまく機能し、RapidXMLは大きなファイルの処理に優れています。

C#およびC:さまざまなパラダイムの探索C#およびC:さまざまなパラダイムの探索May 08, 2025 am 12:06 AM

C#とCの主な違いは、メモリ管理、多型の実装、パフォーマンスの最適化です。 1)C#はゴミコレクターを使用してメモリを自動的に管理し、Cは手動で管理する必要があります。 2)C#は、インターフェイスと仮想方法を介して多型を実現し、Cは仮想関数と純粋な仮想関数を使用します。 3)C#のパフォーマンスの最適化は、構造と並列プログラミングに依存しますが、Cはインライン関数とマルチスレッドを通じて実装されます。

C XML解析:テクニックとベストプラクティスC XML解析:テクニックとベストプラクティスMay 07, 2025 am 12:06 AM

DOMおよびSAXメソッドを使用して、CのXMLデータを解析できます。1)DOMのXMLをメモリに解析することは、小さなファイルに適していますが、多くのメモリを占有する可能性があります。 2)サックス解析はイベント駆動型であり、大きなファイルに適していますが、ランダムにアクセスすることはできません。適切な方法を選択してコードを最適化すると、効率が向上する可能性があります。

特定のドメインのc:その拠点の調査特定のドメインのc:その拠点の調査May 06, 2025 am 12:08 AM

Cは、高性能と柔軟性のため、ゲーム開発、組み込みシステム、金融取引、科学的コンピューティングの分野で広く使用されています。 1)ゲーム開発では、Cは効率的なグラフィックレンダリングとリアルタイムコンピューティングに使用されます。 2)組み込みシステムでは、Cのメモリ管理とハードウェア制御機能が最初の選択肢になります。 3)金融取引の分野では、Cの高性能はリアルタイムコンピューティングのニーズを満たしています。 4)科学的コンピューティングでは、Cの効率的なアルゴリズムの実装とデータ処理機能が完全に反映されています。

神話を暴く:Cは本当に死んだ言語ですか?神話を暴く:Cは本当に死んだ言語ですか?May 05, 2025 am 12:11 AM

Cは死んでいませんが、多くの重要な領域で栄えています。1)ゲーム開発、2)システムプログラミング、3)高性能コンピューティング、4)ブラウザとネットワークアプリケーション、Cは依然として主流の選択であり、その強力な活力とアプリケーションのシナリオを示しています。

C#対C:プログラミング言語の比較分析C#対C:プログラミング言語の比較分析May 04, 2025 am 12:03 AM

C#とCの主な違いは、構文、メモリ管理、パフォーマンスです。1)C#構文は最新であり、LambdaとLinqをサポートし、CはC機能を保持し、テンプレートをサポートします。 2)C#はメモリを自動的に管理し、Cは手動で管理する必要があります。 3)CパフォーマンスはC#よりも優れていますが、C#パフォーマンスも最適化されています。

Cを使用したXMLアプリケーションの構築:実用的な例Cを使用したXMLアプリケーションの構築:実用的な例May 03, 2025 am 12:16 AM

tinyxml、pugixml、またはlibxml2ライブラリを使用して、CでXMLデータを処理できます。1)XMLファイルを解析する:DOMまたはSAXメソッドを使用し、DOMは小さなファイルに適しており、SAXは大きなファイルに適しています。 2)XMLファイルを生成:データ構造をXML形式に変換し、ファイルに書き込みます。これらの手順を通じて、XMLデータを効果的に管理および操作できます。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

SublimeText3 Mac版

SublimeText3 Mac版

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

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター