国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

最小総移動(dòng)距離

Nov 03, 2024 am 03:45 AM

2463。最小総移動(dòng)距離

難易度: 難しい

トピック: 配列、動(dòng)的プログラミング、ソート

X 軸にはいくつかのロボットと工場(chǎng)があります。整數(shù)配列ロボットが與えられます。ここで、 robot[i] は i 番目 ロボットの位置です。また、2D 整數(shù)配列ファクトリーも與えられます。ここで、factory[j] = [positionj, limitj] は、positionj が j の位置であることを示します。 番目の工場(chǎng)と、j番目の工場(chǎng)は最大でもj臺(tái)のロボットを修理できるとのこと。

各ロボットの位置はユニークです。各工場(chǎng)の立場(chǎng)も獨(dú)特です。ロボットは最初は工場(chǎng)と同じ位置にあることができることに注意してください。

すべてのロボットは最初は壊れています。彼らは一方向に進(jìn)み続けます。方向は、X 軸の負(fù)の方向または正の方向になります。ロボットが限界に達(dá)していない工場(chǎng)に到達(dá)すると、工場(chǎng)はロボットを修理し、ロボットは動(dòng)きを停止します。

いつでも、一部 ロボットの最初の移動(dòng)方向を設(shè)定できます。あなたの目標(biāo)は、すべてのロボットの総移動(dòng)距離を最小限に抑えることです。

すべてのロボットが移動(dòng)した最小合計(jì)距離を返します。テスト ケースは、すべてのロボットを修復(fù)できるように生成されます。

次のことに注意してください

  • すべてのロボットは同じ速度で動(dòng)きます。
  • 2 臺(tái)のロボットが同じ方向に移動(dòng)した場(chǎng)合、衝突することはありません。
  • 2 臺(tái)のロボットが反対方向に移動(dòng)し、ある時(shí)點(diǎn)で出會(huì)った場(chǎng)合、それらは衝突しません。それらは互いに交差します。
  • ロボットが限界に達(dá)した工場(chǎng)の前を通過(guò)すると、まるで存在しないかのように工場(chǎng)を橫切ります。
  • ロボットが位置 x から位置 y に移動(dòng)した場(chǎng)合、移動(dòng)距離は |y - x| です。

例 1:

Minimum Total Distance Traveled

  • 入力: ロボット = [0,4,6]、ファクトリー = [[2,2],[6,2]]
  • 出力: 4
  • 説明: 図に示すように:
    • 位置 0 の最初のロボットが正の方向に移動(dòng)します。第一工場(chǎng)での修理となります。
    • 位置 4 の 2 番目のロボットが負(fù)の方向に移動(dòng)します。第一工場(chǎng)での修理となります。
    • 位置 6 にある 3 番目のロボットは、第 2 工場(chǎng)で修理されます。移動(dòng)する必要はありません。
    • 最初の工場(chǎng)の制限は 2 で、2 つのロボットが固定されました。
    • 第 2 工場(chǎng)の制限は 2 臺(tái)で、ロボットは 1 臺(tái)固定されました。
    • 合計(jì)距離は |2 - 0| です。 |2 - 4| |6 - 6| = 4. 4 よりも優(yōu)れた合計(jì)距離を達(dá)成することはできないことがわかります。

例 2:

Minimum Total Distance Traveled

  • 入力: ロボット = [1,-1]、ファクトリー = [[-2,1],[2,1]]
  • 出力: 2
  • 説明: 図に示すように:
    • 位置 1 の最初のロボットが正の方向に移動(dòng)します。第二工場(chǎng)での修理となります。
    • 位置 -1 にある 2 番目のロボットは負(fù)の方向に移動(dòng)します。第一工場(chǎng)での修理となります。
    • 最初の工場(chǎng)の制限は 1 で、1 つのロボットを固定しました。
    • 第 2 工場(chǎng)の制限は 1 で、ロボットを 1 臺(tái)固定しました。
    • 合計(jì)距離は |2 - 1| です |(-2) - (-1)| = 2. 2 よりも優(yōu)れた合計(jì)距離を達(dá)成することはできないことがわかります。

制約:

  • 1
  • factory[j].length == 2
  • -109 <= ロボット[i]、位置 j <= 109
  • 0 <= 制限j <= robot.length
  • 入力は、すべてのロボットを常に修復(fù)できるように生成されます。

ヒント:

  1. ロボットと工場(chǎng)を位置ごとに並べ替えます。
  2. 分類後、各工場(chǎng)がロボットの一部のサブセグメントを修理する必要があることに注意してください。
  3. 最初の i 個(gè)のロボットと最初の j 個(gè)の工場(chǎng)を修理するための最小合計(jì)距離を見(jiàn)つけます。

解決策:

ソートされたロボットとファクトリー配列を使用して動(dòng)的プログラミングを使用できます。その考え方は、各工場(chǎng)の修理能力を尊重し、各ロボットが工場(chǎng)で修理するために移動(dòng)しなければならない距離を最小限に抑えることです。このアプローチを段階的に詳しく説明します:

  1. ロボットとファクトリー配列を位置で並べ替えます。並べ替えると、近くのロボットを近くの工場(chǎng)に割り當(dāng)てることができるため、移動(dòng)距離を最小限に抑えることができます。

  2. 動(dòng)的プログラミング手法: 2D DP テーブル dp[i][j] を定義します。ここで:

    • i は最初の i ロボットを表します。
    • j は最初の j 個(gè)のファクトリーを表します。
    • dp[i][j] には、これらの j 個(gè)のファクトリーを使用してこれらの i 個(gè)のロボットを修理するための最小合計(jì)距離が格納されます。
  3. 狀態(tài)遷移:

    • 各工場(chǎng)について、制限內(nèi)で連続するロボットのサブセットを修復(fù)してみます。
    • 位置 p にある工場(chǎng) j について、各ロボットから工場(chǎng)の位置までの距離を合計(jì)することで、それに k 臺(tái)のロボットを割り當(dāng)てるために必要な最小距離を計(jì)算します。
    • 修理するロボットの數(shù)を減らすか、工場(chǎng)の能力を最大限に活用するかの最小値を選択して、DP の狀態(tài)を更新します。

このソリューションを PHP で実裝してみましょう: 2463。最小総移動(dòng)距離






説明:

  • 並べ替え: 近くのロボットを近くの工場(chǎng)に確実に割り當(dāng)てるために、ロボットと工場(chǎng)を位置によって並べ替えます。
  • DP 初期化: どの工場(chǎng)でもロボットが修理されていないということは距離がゼロであることを意味するため、dp[0][0] = 0 を初期化します。
  • 動(dòng)的プログラミングの移行:
    • 各工場(chǎng) j について、その制限內(nèi)で先行する k 個(gè)のロボットの修理を試みます。
    • 合計(jì)距離は sumDist に累積されます。
    • k 臺(tái)のロボットを修復(fù)した後、距離と以前の狀態(tài)を考慮して dp[i][j] を最小値で更新します。

複雑

  • 時(shí)間計(jì)算量: O(n * m * L) ここで、n はロボットの數(shù)、m は工場(chǎng)の數(shù)、L は工場(chǎng)が処理できる修理の上限です。
  • 空間複雑度: DP テーブルの O(n * m)。

このソリューションは、工場(chǎng)出荷時(shí)の制限內(nèi)で修理されるすべてのロボットの最小移動(dòng)距離を効率的に計(jì)算します。

連絡(luò)先リンク

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

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

  • LinkedIn
  • GitHub

以上が最小総移動(dòng)距離の詳細(xì)內(nèi)容です。詳細(xì)については、PHP 中國(guó)語(yǔ) Web サイトの他の関連記事を參照してください。

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

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫像を無(wú)料で

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

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無(wú)料のコードエディター

SublimeText3 中國(guó)語(yǔ)版

SublimeText3 中國(guó)語(yǔ)版

中國(guó)語(yǔ)版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

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

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開(kāi)発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

PHPに認(rèn)証と承認(rèn)を?qū)g裝するにはどうすればよいですか? PHPに認(rèn)証と承認(rèn)を?qū)g裝するにはどうすればよいですか? Jun 20, 2025 am 01:03 AM

tosecurelyhandLeauthenticationAndauthorizationInizationInization、followTheSteps:1.LwayShashPasswordswithPassword_hash()andverifyusingpassword_verify()、usepreparedStatementStatementStatementStatementStatementStain、andstoreUserdatain $ _SessionAfterlogin.2.implementRementRementRementRementRementRementRementRole

PHPでファイルアップロードを安全に処理するにはどうすればよいですか? PHPでファイルアップロードを安全に処理するにはどうすればよいですか? Jun 19, 2025 am 01:05 AM

PHPでファイルアップロードを安全に処理するために、コアはファイルタイプを確認(rèn)し、ファイルの名前を変更し、権限を制限することです。 1。Finfo_File()を使用して実際のMIMEタイプを確認(rèn)し、Image/JPEGなどの特定のタイプのみが許可されます。 2。uniqid()を使用してランダムファイル名を生成し、非webルートディレクトリに保存します。 3. PHP.iniおよびHTMLフォームを介してファイルサイズを制限し、ディレクトリ権限を0755に設(shè)定します。 4. Clamavを使用してマルウェアをスキャンしてセキュリティを強(qiáng)化します。これらの手順は、セキュリティの脆弱性を効果的に防止し、ファイルのアップロードプロセスが安全で信頼性が高いことを確認(rèn)します。

PHPの==(ゆるい比較)と===(厳密な比較)の違いは何ですか? PHPの==(ゆるい比較)と===(厳密な比較)の違いは何ですか? Jun 19, 2025 am 01:07 AM

PHPでは、==と==の主な違いは、タイプチェックの厳格さです。 ==タイプ変換は比較の前に実行されます。たとえば、5 == "5"はtrueを返します。===リクエストは、trueが返される前に値とタイプが同じであることを要求します。たとえば、5 === "5"はfalseを返します。使用シナリオでは、===はより安全で、最初に使用する必要があります。==は、タイプ変換が必要な場(chǎng)合にのみ使用されます。

PHP(、 - 、 *、 /、%)で算術(shù)操作を?qū)g行するにはどうすればよいですか? PHP(、 - 、 *、 /、%)で算術(shù)操作を?qū)g行するにはどうすればよいですか? Jun 19, 2025 pm 05:13 PM

PHPで基本的な數(shù)學(xué)操作を使用する方法は次のとおりです。1。追加標(biāo)識(shí)は、整數(shù)と浮動(dòng)小數(shù)點(diǎn)數(shù)をサポートし、変數(shù)にも使用できます。文字列番號(hào)は自動(dòng)的に変換されますが、依存関係には推奨されません。 2。減算標(biāo)識(shí)の使用 - 標(biāo)識(shí)、変數(shù)は同じであり、タイプ変換も適用されます。 3.乗算サインは、數(shù)字や類似の文字列に適した標(biāo)識(shí)を使用します。 4.分割はゼロで割らないようにする必要がある分割 /標(biāo)識(shí)を使用し、結(jié)果は浮動(dòng)小數(shù)點(diǎn)數(shù)である可能性があることに注意してください。 5.モジュラス標(biāo)識(shí)を採(cǎi)取することは、奇妙な數(shù)と偶數(shù)を判斷するために使用でき、負(fù)の數(shù)を処理する場(chǎng)合、殘りの兆候は配當(dāng)と一致しています。これらの演算子を正しく使用するための鍵は、データ型が明確であり、境界の狀況がうまく処理されるようにすることです。

PHPのNOSQLデータベース(Mongodb、Redisなど)とどのように対話できますか? PHPのNOSQLデータベース(Mongodb、Redisなど)とどのように対話できますか? Jun 19, 2025 am 01:07 AM

はい、PHPは、特定の拡張機(jī)能またはライブラリを使用して、MongoDBやRedisなどのNOSQLデータベースと対話できます。まず、MongoDBPHPドライバー(PECLまたはComposerを介してインストール)を使用して、クライアントインスタンスを作成し、データベースとコレクションを操作し、挿入、クエリ、集約、その他の操作をサポートします。第二に、PredisライブラリまたはPhpredis拡張機(jī)能を使用してRedisに接続し、キー価値設(shè)定と取得を?qū)g行し、高性能シナリオにPhpredisを推奨しますが、Predisは迅速な展開(kāi)に便利です。どちらも生産環(huán)境に適しており、十分に文書化されています。

最新のPHP開(kāi)発とベストプラクティスを最新の狀態(tài)に保つにはどうすればよいですか? 最新のPHP開(kāi)発とベストプラクティスを最新の狀態(tài)に保つにはどうすればよいですか? Jun 23, 2025 am 12:56 AM

postaycurrentwithpdevellyments andbest practices、follow keynewsourceslikephp.netandphpweekly、egagewithcommunitiessonforums andconferences、keeptooling and gradivallyadoptnewfeatures、andreadorcontributeTopensourceprijeprijeprijeptrijeprijeprests.

PHPとは何ですか、そしてなぜそれがWeb開(kāi)発に使用されるのですか? PHPとは何ですか、そしてなぜそれがWeb開(kāi)発に使用されるのですか? Jun 23, 2025 am 12:55 AM

PhpBecamepopularforwebdevelopmentduetoitseaseaseaseaseasease、SeamlessintegrationWithhtml、widespreadhostingsupport、andalargeecosystemincludingframeworkelavelandcmsplatformslikewordspresspressinsinsionsisionsisionsisionsisionsionsionsisionsionsionsisionsisions

PHPタイムゾーンを設(shè)定する方法は? PHPタイムゾーンを設(shè)定する方法は? Jun 25, 2025 am 01:00 AM

tosettherighttimezoneInphp、usedate_default_timezone_set()functionthestthestofyourscriptwithavalididentifiersiersuchas'america/new_york'.1.usedate_default_timezone_set()beforeanydate/timefunctions.2.2.Altertentally、confuturethephp.inifilebyset.

See all articles