2463。最小總行駛距離
難度:難
主題:陣列、動(dòng)態(tài)規(guī)劃、排序
X軸上有一些機(jī)器人和工廠。給定一個(gè)整數(shù)陣列機(jī)器人,其中 robots[i] 是第 ith 個(gè)機(jī)器人的位置。您還得到一個(gè)2D 整數(shù)陣列工廠,其中factory[j] = [positionj, limitj] 表示positionj 是j 的位置第個(gè)工廠且第j第個(gè)工廠最多可以維修j個(gè)機(jī)器人。
每個(gè)機(jī)器人的位置都是獨(dú)一無二的。每個(gè)工廠的定位也獨(dú)一無二。請(qǐng)注意,機(jī)器人最初可以處?kù)杜c工廠相同的位置。
所有機(jī)器人一開始都?jí)牧?;他們一直朝著一個(gè)方向前進(jìn)。此方向可以是X軸的負(fù)方向或正方向。當(dāng)機(jī)器人到達(dá)未達(dá)極限的工廠時(shí),工廠會(huì)修理機(jī)器人,然後機(jī)器人就會(huì)停止移動(dòng)。
隨時(shí),您可以為某個(gè)機(jī)器人設(shè)定初始移動(dòng)方向。您的目標(biāo)是最小化所有機(jī)器人行駛的總距離。
返回所有機(jī)器人行駛的最小總距離。產(chǎn)生測(cè)試用例,以便可以修復(fù)所有機(jī)器人。
請(qǐng)注意
- 所有機(jī)器人以相同的速度移動(dòng)。
- 如果兩個(gè)機(jī)器人朝同一方向移動(dòng),它們永遠(yuǎn)不會(huì)碰撞。
- 如果兩個(gè)機(jī)器人向相反方向移動(dòng)並且在某個(gè)時(shí)刻相遇,它們不會(huì)發(fā)生碰撞。他們互相交叉。
- 如果機(jī)器人經(jīng)過一家達(dá)到極限的工廠,它就會(huì)穿過它,就好像它不存在一樣。
- 如果機(jī)器人從位置 x 移動(dòng)到位置 y,則移動(dòng)的距離為 |y - x|。
範(fàn)例1:
- 輸入: 機(jī)器人 = [0,4,6],工廠 = [[2,2],[6,2]]
- 輸出: 4
-
說明:如圖:
- 位置 0 的第一個(gè)機(jī)器人朝正方向移動(dòng)。會(huì)在第一工廠修復(fù)。
- 位置 4 處的第二個(gè)機(jī)器人向負(fù)方向移動(dòng)。會(huì)在第一工廠修復(fù)。
- 6號(hào)位的第三臺(tái)機(jī)器人將在第二工廠進(jìn)行維修。它不需要移動(dòng)。
- 第一個(gè)工廠的限制是2個(gè),固定了2個(gè)機(jī)器人。
- 第二工廠限制為2個(gè),固定了1個(gè)機(jī)器人。
- 總距離為 |2 - 0| |2 - 4| |6 - 6| = 4. 可以證明我們無法得到比 4 更好的總距離。
範(fàn)例2:
- 輸入: 機(jī)器人 = [1,-1], 工廠 = [[-2,1],[2,1]]
- 輸出: 2
-
說明:如圖:
- 位置 1 的第一個(gè)機(jī)器人朝正方向移動(dòng)。會(huì)在第二工廠修復(fù)。
- 位置-1處的第二個(gè)機(jī)器人向負(fù)方向移動(dòng)。會(huì)在第一工廠修復(fù)。
- 第一個(gè)工廠的限制是1個(gè),固定了1個(gè)機(jī)器人。
- 第二工廠限制為1個(gè),固定了1個(gè)機(jī)器人。
- 總距離為 |2 - 1| |(-2) - (-1)| = 2. 可以證明我們無法得到比 2 更好的總距離。
約束:
- 1
- 工廠[j].length == 2
- -109 9
- 0 j
- 將產(chǎn)生輸入,以便始終可以修復(fù)每個(gè)機(jī)器人。
提示:
- 按位置對(duì)機(jī)器人和工廠進(jìn)行排序。
- 排序後,注意每個(gè)工廠都應(yīng)該修復(fù)部分機(jī)器人。
- 找出修復(fù)前 j 個(gè)工廠的前 i 個(gè)機(jī)器人的最小總距離。
解:
我們可以對(duì)排序的機(jī)器人和工廠陣列使用動(dòng)態(tài)程式設(shè)計(jì)。其想法是最大限度地縮短每個(gè)機(jī)器人到工廠維修所需的距離,同時(shí)尊重每個(gè)工廠的維修能力。以下是此方法的逐步細(xì)分:
按位置對(duì)機(jī)器人和工廠數(shù)組進(jìn)行排序。排序有助於最大限度地縮短行進(jìn)距離,因?yàn)槲覀兛梢詫⒏浇臋C(jī)器人分配到附近的工廠。
-
動(dòng)態(tài)規(guī)劃方法:我們定義一個(gè)2D DP表dp[i][j],其中:
- i 代表第 i 個(gè)機(jī)器人。
- j代表前j個(gè)工廠。
- dp[i][j] 儲(chǔ)存使用這 j 個(gè)工廠修復(fù)這 i 個(gè)機(jī)器人的最小總距離。
-
態(tài)轉(zhuǎn)換:
- 對(duì)於每個(gè)工廠,請(qǐng)嘗試在其限制內(nèi)修復(fù)連續(xù)機(jī)器人的子集。
- 對(duì)於位置 p 的工廠 j,透過將每個(gè)機(jī)器人到工廠位置的距離相加,計(jì)算為其分配 k 個(gè)機(jī)器人所需的最小距離。
- 透過在修復(fù)較少的機(jī)器人或充分利用工廠產(chǎn)能之間選擇最小值來更新 DP 狀態(tài)。
讓我們用 PHP 實(shí)作這個(gè)解:2463。最小總行駛距離
<?php /** * @param Integer[] $robot * @param Integer[][] $factory * @return Integer */ function minimumTotalDistance($robot, $factory) { ... ... ... /** * go to ./solution.php */ } // Test cases $robot = [0, 4, 6]; $factory = [[2, 2], [6, 2]]; echo minimumTotalDistance($robot, $factory); // Output: 4 $robot = [1, -1]; $factory = [[-2, 1], [2, 1]]; echo minimumTotalDistance($robot, $factory); // Output: 2 ?>
解釋:
- 排序:我們按位置對(duì)機(jī)器人和工廠進(jìn)行排序,以確保將附近的機(jī)器人分配到附近的工廠。
- DP初始化:初始化dp[0][0] = 0,因?yàn)闆]有工廠修理機(jī)器人意味著零距離。
-
動(dòng)態(tài)規(guī)劃轉(zhuǎn)換:
- 對(duì)於每個(gè)工廠j,我們嘗試在其限制範(fàn)圍內(nèi)修復(fù)其前面的k個(gè)機(jī)器人。
- 總距離在 sumDist 累積。
- 考慮到距離和之前的狀態(tài),我們將 dp[i][j] 更新為修復(fù) k 個(gè)機(jī)器人後的最小值。
複雜
- 時(shí)間複雜度:O(n * m * L),其中n是機(jī)器人數(shù)量,m是工廠數(shù)量,L是任何工廠可以處理的最大維修限制。
- 空間複雜度:DP 表的 O(n * m)。
此解決方案可有效計(jì)算所有待維修機(jī)器人在工廠限制內(nèi)的最小行進(jìn)距離。
聯(lián)絡(luò)連結(jié)
如果您發(fā)現(xiàn)本系列有幫助,請(qǐng)考慮在 GitHub 上給 存儲(chǔ)庫(kù) 一個(gè)星號(hào)或在您最喜歡的社交網(wǎng)絡(luò)上分享該帖子? 。您的支持對(duì)我來說意義重大!
如果您想要更多類似的有用內(nèi)容,請(qǐng)隨時(shí)關(guān)注我:
- 領(lǐng)英
- GitHub
以上是最小總行駛距離的詳細(xì)內(nèi)容。更多資訊請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

熱AI工具

Undress AI Tool
免費(fèi)脫衣圖片

Undresser.AI Undress
人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強(qiáng)大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6
視覺化網(wǎng)頁(yè)開發(fā)工具

SublimeText3 Mac版
神級(jí)程式碼編輯軟體(SublimeText3)

PHP變量作用域常見問題及解決方法包括:1.函數(shù)內(nèi)部無法訪問全局變量,需使用global關(guān)鍵字或參數(shù)傳入;2.靜態(tài)變量用static聲明,只初始化一次並在多次調(diào)用間保持值;3.超全局變量如$_GET、$_POST可在任何作用域直接使用,但需注意安全過濾;4.匿名函數(shù)需通過use關(guān)鍵字引入父作用域變量,修改外部變量則需傳遞引用。掌握這些規(guī)則有助於避免錯(cuò)誤並提升代碼穩(wěn)定性。

要安全處理PHP文件上傳需驗(yàn)證來源與類型、控製文件名與路徑、設(shè)置服務(wù)器限制並二次處理媒體文件。 1.驗(yàn)證上傳來源通過token防止CSRF並通過finfo_file檢測(cè)真實(shí)MIME類型使用白名單控制;2.重命名文件為隨機(jī)字符串並根據(jù)檢測(cè)類型決定擴(kuò)展名存儲(chǔ)至非Web目錄;3.PHP配置限制上傳大小及臨時(shí)目錄Nginx/Apache禁止訪問上傳目錄;4.GD庫(kù)重新保存圖片清除潛在惡意數(shù)據(jù)。

PHP註釋代碼常用方法有三種:1.單行註釋用//或#屏蔽一行代碼,推薦使用//;2.多行註釋用/.../包裹代碼塊,不可嵌套但可跨行;3.組合技巧註釋如用/if(){}/控制邏輯塊,或配合編輯器快捷鍵提升效率,使用時(shí)需注意閉合符號(hào)和避免嵌套。

AgeneratorinPHPisamemory-efficientwaytoiterateoverlargedatasetsbyyieldingvaluesoneatatimeinsteadofreturningthemallatonce.1.Generatorsusetheyieldkeywordtoproducevaluesondemand,reducingmemoryusage.2.Theyareusefulforhandlingbigloops,readinglargefiles,or

寫好PHP註釋的關(guān)鍵在於明確目的與規(guī)範(fàn),註釋應(yīng)解釋“為什麼”而非“做了什麼”,避免冗餘或過於簡(jiǎn)單。 1.使用統(tǒng)一格式,如docblock(/*/)用於類、方法說明,提升可讀性與工具兼容性;2.強(qiáng)調(diào)邏輯背後的原因,如說明為何需手動(dòng)輸出JS跳轉(zhuǎn);3.在復(fù)雜代碼前添加總覽性說明,分步驟描述流程,幫助理解整體思路;4.合理使用TODO和FIXME標(biāo)記待辦事項(xiàng)與問題,便於後續(xù)追蹤與協(xié)作。好的註釋能降低溝通成本,提升代碼維護(hù)效率。

ToinstallPHPquickly,useXAMPPonWindowsorHomebrewonmacOS.1.OnWindows,downloadandinstallXAMPP,selectcomponents,startApache,andplacefilesinhtdocs.2.Alternatively,manuallyinstallPHPfromphp.netandsetupaserverlikeApache.3.OnmacOS,installHomebrew,thenrun'bre

在PHP中獲取字符串特定索引字符可用方括號(hào)或花括號(hào),但推薦方括號(hào);索引從0開始,超出範(fàn)圍訪問返回空值,不可賦值;處理多字節(jié)字符需用mb_substr。例如:$str="hello";echo$str[0];輸出h;而中文等字符需用mb_substr($str,1,1)獲取正確結(jié)果;實(shí)際應(yīng)用中循環(huán)訪問前應(yīng)檢查字符串長(zhǎng)度,動(dòng)態(tài)字符串需驗(yàn)證有效性,多語言項(xiàng)目建議統(tǒng)一使用多字節(jié)安全函數(shù)。

易於效率,啟動(dòng)啟動(dòng)tingupalocalserverenverenvirestoolslikexamppandacodeeditorlikevscode.1)installxamppforapache,mysql,andphp.2)uscodeeditorforsyntaxssupport.3)
