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

ホームページ バックエンド開発 PHPチュートリアル 要素を交換して、辭書編集的に最小の配列を作成します

要素を交換して、辭書編集的に最小の配列を作成します

Jan 26, 2025 am 02:04 AM

Make Lexicographically Smallest Array by Swapping Elements

2948。要素を交換して辭書順に最小の配列を作成

難易度:

トピック: 配列、結(jié)合検索、ソート

正の 整數(shù)の 0 インデックス 配列と正の整數(shù)制限が與えられます。

1 回の操作で、任意の 2 つのインデックス i と j を選択し、nums[i] と nums[j] を入れ替えることができます。if |nums[i] - nums[j]| <= 制限。

操作を何回でも実行することで取得できる 辭書編集上最小の配列を返します。

配列 a は、a と b が異なる最初の位置に、配列 a の要素が b の対応する要素よりも小さい場(chǎng)合、辭書編集的に配列 b より小さくなります。たとえば、配列 [2,10,3] は、インデックス 0 と 2

例 1:

  • 入力: 數(shù)値 = [1,5,3,9,8]、制限 = 2
  • 出力: [1,3,5,8,9]
  • 説明: 操作を 2 回適用します:
      nums[1] を nums[2] と交換します。配列は [1,3,5,9,8]
    • になります。
    • nums[3] を nums[4] と交換します。配列は [1,3,5,8,9]
    • になります。
    • これ以上操作を適用しても、辭書編集的に小さい配列を取得することはできません。
    • 異なる操作を?qū)g行しても同じ結(jié)果が得られる可能性があることに注意してください。

例 2:

  • 入力: 數(shù)値 = [1,7,6,18,2,1]、制限 = 3
  • 出力: [1,6,7,18,1,2]
  • 説明: 操作を 3 回適用します。
      nums[1] を nums[2] と交換します。配列は [1,6,7,18,2,1]
    • になります。
    • nums[0] を nums[4] と交換します。配列は [2,6,7,18,1,1]
    • になります。
    • nums[0] を nums[5] と交換します。配列は [1,6,7,18,1,2]
    • になります。
    • これ以上操作を適用しても、辭書編集的に小さい配列を取得することはできません。

例 3:

  • 入力: 數(shù)値 = [1,7,28,19,10]、制限 = 3
  • 出力: [1,7,28,19,10]
  • 説明: [1,7,28,19,10] は、2 つのインデックスに演算を適用できないため、取得できる辭書編集上の最小の配列です。

例 4:

  • 入力: 數(shù)値 = [1,60,34,84,62,56,39,76,49,38]、制限 = 4
  • 出力: [1,56,34,84,60,62,38,76,49,39]

制約:

    1 5 1 9 1 9

ヒント:

  1. numのすべての要素がノードであり、條件を満たすペアがそれらの間にエッジを持っている仮想グラフを構(gòu)築します。
  2. すべてのエッジを構(gòu)築する代わりに、接続されたコンポーネントのみを気にします。 dsu?
  3. を使用できますか
  4. sort nums。ここで、連続した要素が同じ接続コンポーネントに屬しているかどうかを確認(rèn)するためのエッジがあるかどうかを考慮する必要があります。したがって、すべての接続されたコンポーネントは、並べ替え後に位置となる要素のリストになります。
  5. 0からnums.length -1のnumsの各インデックスについて、接続されたコンポーネントにある現(xiàn)在の最小値に変更し、接続されたコンポーネントからその値を削除できます。
  6. 解決策:
問題は、條件の対象となる配列の要素を交換することにより、

辭書學(xué)的に最小のアレイを見つけるように求めています。具體的には、それらの間の絶対差(nums [i] - nums [j] |)が與えられた制限以下である場(chǎng)合、2つの要素nums [i]とnums [j]を交換することができます。

キーポイント

辭書編集順序:アレイAは、最初の異なるインデックスでa [i]&lt; b [i]。

    スワッピング條件
  1. :スワップは、スワップされている數(shù)値の差が≤slime。の場(chǎng)合にのみ許可されます。
  2. Efficive Grounging
  3. :Disjoint Set Union(dsu)または並べ替え手法を使用することにより、有効なスワップで接続された要素をグループ化できます。
  4. 最適な配置
  5. :各グループについて、インデックスと値を並べ替えて最小の順序を達(dá)成します。 アプローチ
  6. constructグループ
  7. :配列を仮想グラフとして扱い、有効なスワップがエッジを定義します。ソートを使用して、接続グループまたはDSUを識(shí)別してインデックスを効率的にグループ化します。

並べ替えグループ:接続されたインデックスの各グループ內(nèi)で、要素を辭書的順序で再配置します。

出力構(gòu)造
    :ソートされた値をそれぞれの位置に戻します。
  1. 計(jì)畫
  2. 抽出(値、インデックス)ペアでペアを使用してソートして、効率的なグループ検出を可能にします。
  3. 並べ替えられた値を繰り返して、限界條件に基づいて接続されたインデックスのグループを形成します。 各グループの場(chǎng)合: インデックスと値を獨(dú)立してソートします。
値を辭書編集順に元の位置に再割り當(dāng)てします。

修正された配列を返します。
  1. このソリューションをPHP:
  2. 2948に実裝しましょう。要素を交換して、辭書編集的に最小のアレイを作成します
    • 説明:
  3. 抽出と並べ替え(g??etNumandIndexes):
  • 簡単に參照できるように、値とインデックスをペアに組み合わせます。
  • ペアを値で並べ替えると、連結(jié)コンポーネントを効率的にグループ化できます。
  • グループ化ロジック:

    • ソートされたペアをスキャンします。連続する値の差が制限値以下の場(chǎng)合は、それらを同じグループに追加します。それ以外の場(chǎng)合は、新しいグループを開始します。
  • 並べ替えと再割り當(dāng)て:

    • 各グループについて:
      • インデックスと値を抽出します。
      • 両方のリストを並べ替えて、最小の値が最小のインデックスに配置されるようにします。
      • 並べ替えられた値を回答配列內(nèi)のそれぞれの位置に再割り當(dāng)てします。
  • 結(jié)果の構(gòu)築:

    • すべてのグループを処理した後、更新された配列を返します。
  • チュートリアルの例

    例1

    入力: 數(shù)値 = [1,5,3,9,8]、制限 = 2

    1. 抽出と並べ替え:

      • ペア: [(1, 0), (5, 1), (3, 2), (9, 3), (8, 4)]
      • ソートされたペア: [(1, 0), (3, 2), (5, 1), (8, 4), (9, 3)]
    2. グループ化:

      • グループ 1: [(1, 0)]
      • グループ 2: [(3, 2), (5, 1)]
      • グループ 3: [(8, 4), (9, 3)]
    3. グループの並べ替え:

      • グループ 1: 変更なし ([1])
      • グループ 2: 値 = [3, 5]、インデックス = [1, 2] → 結(jié)果: [1, 3, 5]
      • グループ 3: 値 = [8, 9]、インデックス = [3, 4] → 結(jié)果: [8, 9]
    4. 最終結(jié)果: [1, 3, 5, 8, 9]

    時(shí)間計(jì)算量

    1. ソート: nums 配列のソートには O(n log n) がかかります。
    2. グループ化: ソートされた配列の線形走査には O(n) がかかります。
    3. グループの並べ替え: 各グループのインデックスと値の並べ替えには、O(k log k) がかかります。kグループのサイズです。すべてのグループを合計(jì)すると、O(n log n) となります。

    全體の時(shí)間計(jì)算量: O(n log n)

    例の出力

    例 2

    入力: 數(shù)値 = [1,7,6,18,2,1]、制限 = 3

    出力: [1,6,7,18,1,2]

    例 3

    入力: 數(shù)値 = [1,7,28,19,10]、制限 = 3

    出力: [1,7,28,19,10]

    このアプローチは、並べ替えを使用して接続されたコンポーネントを特定し、各コンポーネント內(nèi)の値を再配置して辭書編集的に最小の配列を?qū)g現(xiàn)することで、問題を効率的に処理します。並べ替えとグループ処理を活用することで、O(n log n) の複雑さを持つ最適なソリューションを保証します。

    連絡(luò)先リンク

    このシリーズが役立つと思われた場(chǎng)合は、GitHub で リポジトリ にスターを付けるか、お?dú)荬巳毪辘违僵`シャル ネットワークで投稿を共有することを検討してください。あなたのサポートは私にとって大きな意味を持ちます!

    このような役立つコンテンツがさらに必要な場(chǎng)合は、お?dú)葺Xにフォローしてください:

    • LinkedIn
    • GitHub

    以上が要素を交換して、辭書編集的に最小の配列を作成しますの詳細(xì)內(nèi)容です。詳細(xì)については、PHP 中國語 Web サイトの他の関連記事を參照してください。

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

    ホット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

    強(qiáng)力な PHP 統(tǒng)合開発環(huán)境

    ドリームウィーバー CS6

    ドリームウィーバー CS6

    ビジュアル Web 開発ツール

    SublimeText3 Mac版

    SublimeText3 Mac版

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

    2つのPHPアレイを組み合わせる方法ユニークな値は? 2つのPHPアレイを組み合わせる方法ユニークな値は? Jul 02, 2025 pm 05:18 PM

    2つのPHPアレイをマージし、一意の値を保持するには、2つの主要な方法があります。 1.インデックスアレイまたは重複排除のみの場(chǎng)合、array_mergeとarray_uniqueの組み合わせを使用します:最初のマージArray_merge($ array1、$ array2)を使用してから、array_unique()を使用して、最終的にすべての一意の値を含む新しいアレイを取得します。 2。関連アレイと最初の配列のキー値のペアを保持したい場(chǎng)合は、演算子を使用してください。$ result = $ array1 $ array2。これらの2つの方法は、キー名が保持されているか焦點(diǎn)があるかに応じて、異なるシナリオに適用できます。

    パスワード強(qiáng)度のPHP Regex パスワード強(qiáng)度のPHP Regex Jul 03, 2025 am 10:33 AM

    パスワードの強(qiáng)度を判斷するには、定期的な処理と論理処理を組み合わせる必要があります?;镜膜室摔弦韵陇蓼欷蓼埂?。長さは8桁以上です。 2。少なくとも小文字、大文字、および數(shù)字を含む。 3。特別な文字制限を追加できます。高度な側(cè)面に関しては、文字の継続的な重複と漸進(jìn)的/減少シーケンスを避ける必要があります。これには、PHP機(jī)能検出が必要です。同時(shí)に、ブラックリストを?qū)毪筏?、パスワードや123456などの一般的な弱いパスワードをフィルタリングする必要があります。最後に、評(píng)価の精度を向上させるためにZXCVBNライブラリを組み合わせることをお?jiǎng)幛幛筏蓼埂?/p>

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

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

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

    PHP変數(shù)スコープの一般的な問題とソリューションには次のものが含まれます。1。グローバル変數(shù)は関數(shù)內(nèi)でアクセスできず、グローバルキーワードまたはパラメーターを使用して渡す必要があります。 2。靜的変數(shù)は靜的で宣言され、1回のみ初期化され、値は複數(shù)の呼び出し間で維持されます。 3. $ _GETや$ _POSTなどのハイパーグローバル変數(shù)は、任意の範(fàn)囲で直接使用できますが、安全なフィルタリングに注意を払う必要があります。 4.匿名関數(shù)は、使用キーワードを使用して親スコープ変數(shù)を?qū)毪工氡匾ⅳ辍⑼獠繅鋽?shù)を変更する場(chǎng)合は、參照を渡す必要があります。これらのルールを習(xí)得すると、エラーを回避し、コードの安定性が向上するのに役立ちます。

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

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

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

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

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

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

    PHPで配列を作成する方法は? PHPで配列を作成する方法は? Jul 02, 2025 pm 05:01 PM

    PHPで配列を作成するには、Array()関數(shù)を使用するか、ブラケットを使用する方法は2つあります。 1. Array()関數(shù)を使用することは、適切な互換性を備えた従來の方法です。 $ fruits = array( "apple"、 "banana"、 "orange")などのインデックス配列、および$ user = array( "name" => "john"、 "age" => 25)などの連想配列を定義します。 2。[]を使用することは、$ COLORなどのPHP5.4以降、より簡単なサポート方法です

    See all articles