一道dp錯題

dis(a,b)就是兩點之間的距離公式

那么這道題該怎么解呢,.先看數據范圍x,y<=1e4,so,18個點兩點之間距離最大18*1e4*sqrt(2)<2^18,所以如果跳過的點大于18個點,那么顯然一個區間內最多不會跳躍超過17個點

現在我們想知道前i個點跳躍幾次在哪跳躍能夠達到最小花費,不妨設跳躍點數為j屬于[0,17],k表示上一個跳躍點距離i的長度

設dp[i][j]表示前i個點跳躍j次,那么上一個跳躍點為i-k-1,由于消耗了j個跳躍點當中的4個跳躍點,所以狀態轉移方程為dp[i][j]=min(dp[i-k-1][j-k]+dis(i,i-k-1)-power(2,j-k-1)+power(2,j-1))為什么要減掉power(2,j-k-1)呢,因為在計算dp[i-k-1][j-k]的時候我們加上過power(2,j-k-1)

首先我們來定義一些基本的數組和變量

constexpr int N = 1e5 + 5;
struct node {double x, y;
};
double dp[N][17];
int P[17];
node a[N];
//i,j,k
//前i個點,有j個點是被跳過的,上一個彎曲點距離點i長度為k,
//i的取值范圍是[2, n],j的取值范圍是[0,min(i-2,16)],k的取值范圍是[1,i-2]
//i能夠取2是為了計算dp[2][0],j表示的是被跳過的點,那么第一個點和第i個點不能被跳過,而且任意兩個點的最大距離為10^4sqrt(10^4)<2^16
//k取1到i-2是因為i-k-1作為起始跳躍點不能為0,且k為0的話起始跳躍點為i的上一個點,兩個點之間無法跳躍 
double dis(int x, int y) {double diss = (a[x].x - a[y].x) * (a[x].x - a[y].x) + (a[x].y - a[y].y) * (a[x].y - a[y].y);diss = std::sqrt(diss);return diss;
}
//dis是用來計算兩點之間的距離的

接下來我們輸入數據

int main() {int n;std::cin >> n;for (int i = 1; i <= n; i++)std::cin >> a[i].x >> a[i].y;P[0] = 1;//p是2的次冪for (int i = 1; i <= 16; i++)P[i] = P[i - 1] * 2;//由于要計算min值,所以不妨把數組都初始化成一個很大的值for (int i = 1; i <= n; i++) {for (int j = 0; j <= 16; j++) {dp[i][j] = 1e18;}}return 0;
}

接下來完成核心代碼

int main() {int n;std::cin >> n;for (int i = 1; i <= n; i++)std::cin >> a[i].x >> a[i].y;P[0] = 1;for (int i = 1; i <= 16; i++)P[i] = P[i - 1] * 2;for (int i = 1; i <= n; i++) {for (int j = 0; j <= 16; j++) {dp[i][j] = 1e18;}}//為什么要單獨把1拎出來,因為我們之前初始化把dp[1][0]也設成1e18了//什么時候會用到1,0?當j==0,i==2,i-1=1時,在下面dp[i][j] = dp[i - 1][j]中會用到dp[1][0] = 0;for (int i = 2; i <= n; i++) {for (int j = 0; j <= std::min(i - 2, 16); j++) {//跳躍點數相同,那就只能是上一個點 dp[i][j] = dp[i - 1][j] + dis(i, i - 1);for (int k = 1; k <= j && i - k - 1 >= 1; k++) {dp[i][j] = std::min(dp[i][j], dp[i - k - 1][j - k] + dis(i - k - 1, i) - P[j - k - 1] + P[j - 1]);}}}double ans = 1e20;for (int j = 0; j <= 16; j++) {ans = std::min(ans, dp[n][j]);}std::cout << std::fixed << std::setprecision(3) << ans << '\n';return 0;
}

分別枚舉i到j的范圍,由于i-1不在狀態轉移方程的范圍內,所以我們要在每一次枚舉k之前特殊計算一次dp[i][j]=dp[i-1][j]+dis(i,i-1);

以上就是這道題的詳細解答,還需勤加練習

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/11784.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/11784.shtml
英文地址,請注明出處:http://en.pswp.cn/web/11784.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【OceanBase診斷調優】—— 轉儲錯誤(錯誤代碼 4138/ORA-01555)

當讀事務很長時&#xff0c;租戶進行轉儲會報 4138/ORA-01555 錯誤。本文介紹該錯誤的處理方法。 適用版本 OceanBase 數據庫 V2.X 及以后的版本 問題現象 當讀事務很長&#xff0c;租戶進行轉儲時會出現以下錯誤。 Oracle 租戶&#xff1a; ORA-01555&#xff1a;snapsho…

Keil調用跟蹤

調試時程序卡在一個位置&#xff0c;恰巧這個函數被很多地方調用&#xff0c;需要知道上一步在哪。 程序暫停后&#xff0c; 查看調用堆棧&#xff0c;點擊Keil菜單欄中的“View”&#xff0c;然后選擇“Call Stack”&#xff08;調用堆棧&#xff09;選項。這將顯示當前的調用…

市場活動系統搭建

精細差異化運營在今天的企業越來越普遍&#xff0c;運營驅動占據了業務經營的主導地位。各種營銷活動&#xff0c;幫助我們差異化運營、激發潛在客戶、帶動連帶消費、增加銷售額度、提升用戶增長、實現品牌宣傳。 天貓、京東上有各種各樣的促銷活動。如&#xff1a;滿減、滿返、…

算法day04

第一題 &#xff1a; 209. 長度最小的子數組 有上題可知&#xff0c;我們會采用雙指針和單調性的思路來解決 我們本題采用左右雙指針從數組的0位置同向前進&#xff0c;所以將此類模型稱為滑塊&#xff1b; 步驟思路如下&#xff1a; 步驟一&#xff1a; 定義所有雙指針都指向…

Prompt提示詞的技巧

Prompt提示詞的技巧 要讓GPT類模型產生最符合我們需求的輸出&#xff0c;我們需要精心設計和調整輸入的提示詞&#xff08;Prompt&#xff09;。 1、明確性&#xff1a; 確保你的提示詞清晰、具體。GPT類模型會根據你給出的信息來生成文本&#xff0c;因此&#xff0c;提供詳…

【實踐】使用vscode來debug go程序的嘗鮮

配置 首先&#xff0c;當然得配置好vscode 的go環境&#xff0c; 裝個go插件就基本滿足了 配置 launch.json, 可以配置多個環境的程序啟動參數&#xff08;很友好&#xff09; {"version": "0.2.0","configurations": [{"name": &…

ArrayList與LinkedList的區別

一、背景與現狀 在Java編程中&#xff0c;ArrayList和LinkedList都是實現List接口的重要類&#xff0c;用于存儲和操作動態大小的元素集合。兩者在Java集合框架中占據了核心地位&#xff0c;并被廣泛應用于各種軟件項目中。然而&#xff0c;盡管它們都提供了類似的功能&#x…

海外客戶開發渠道有哪些

海外客戶開發是一個多元化的過程&#xff0c;涉及線上與線下多個渠道。以下是一些有效的海外客戶開發渠道&#xff1a; 平臺電商&#xff1a; 利用國際B2B電商平臺&#xff0c;如阿里巴巴國際站、 Globalsources、Made-in-China等&#xff0c;這些平臺擁有龐大的國際買家流量&a…

STM32學習和實踐筆記(27):USART串口通信實驗程序

本實驗所要實現的功能是&#xff1a;STM32F1通過USART1實現與PC機對話&#xff0c;STM32F1的USART1收到PC機發來的數據后原封不動的返回給PC機顯示。同時使用D1指示燈不斷閃爍提示系統正常運行。程序框架如下&#xff1a; &#xff08;1&#xff09;初始化USART1&#xff0c;并…

linux 開發常用命令

一、查看 相關服務 1.查看 數據庫 相關服務 這里以mysql 和 redis 為例 &#xff08;1&#xff09;使用 ps 命令 執行命令會列出&#xff0c;“mysql”、“redis”名稱的進程 ps aux | grep redis 示例&#xff1a; rootspray:~# ps aux | grep mysql mysql 1609816 0.…

Flutter 中的 FilterChip 小部件:全面指南

Flutter 中的 FilterChip 小部件&#xff1a;全面指南 在 Flutter 中&#xff0c;FilterChip 是一種特殊類型的 Chip&#xff0c;用于呈現過濾選項。用戶可以通過點擊 FilterChip 來應用相應的過濾條件&#xff0c;這在需要對列表或集合進行篩選的場景中非常有用&#xff0c;如…

51單片機實現俄羅斯方塊游戲編程

一、設計要求 &#xff08;1&#xff09;利用51單片機&#xff0c;設計一款俄羅斯方塊游戲&#xff0c;完成硬件電路的開發和程序的編寫調試&#xff1b; &#xff08;2&#xff09;采用LCD12864液晶作為游戲運行界面&#xff1b; &#xff08;3&#xff09;利用按鍵輸入靈活…

Spring Boot集成dubbo快速入門Demo

1.什么是dubbo&#xff1f; Apache Dubbo 是一款微服務開發框架&#xff0c;它提供了 RPC通信 與 微服務治理 兩大關鍵能力。這意味著&#xff0c;使用 Dubbo 開發的微服務&#xff0c;將具備相互之間的遠程發現與通信能力&#xff0c; 同時利用 Dubbo 提供的豐富服務治理能力…

HTML飄落的花瓣

目錄 寫在前面 HTML???????簡介 完整代碼 代碼分析 系列推薦 寫在最后 寫在前面 本期小編給大家推薦HTML實現的飄落的花瓣&#xff0c;無需安裝軟件&#xff0c;直接下載即可打開~ HTML???????簡介 HTML&#xff08;Hypertext Markup Language&#xff…

探索Playwright:Python下的Web自動化測試革命

在如今這個互聯網技術迅速發展的時代&#xff0c;web應用的質量直接關系著企業的聲譽和用戶的體驗。因此&#xff0c;自動化測試成為了保障軟件質量的重要手段之一。今天&#xff0c;我將帶大家詳細了解一款在測試領域大放異彩的神器——Playwright&#xff0c;并通過Python語言…

一覺醒來 AI科技圈發生的大小事兒 05月13日

&#x1f4f3;博弈論讓 AI 更加正確、高效&#xff0c;LLM 與自己競爭 研究團隊設計了共識博弈&#xff0c;通過讓語言模型的生成器和判別器相互博弈來提高模型的準確性和內部一致性。這種方法不需要對基礎模型進行訓練或修改&#xff0c;可以在筆記本電腦上快速執行。研究結果…

基于微信小程序+JAVA Springboot 實現的【停車場小程序】app+后臺管理系統 (內附設計LW + PPT+ 源碼+ 演示視頻 下載)

項目名稱 項目名稱&#xff1a; 停車場微信小程序的設計與實現 在當前信息技術飛速發展的背景下&#xff0c;停車場微信小程序的開發成為了一個創新的解決方案&#xff0c;旨在提高停車場管理的效率和用戶的停車體驗。本項目通過深入分析現有停車場管理系統的不足&#xff0c…

內存屏障 - LINUX KERNEL MEMORY BARRIERS 上 與 下

內存屏障&#xff08;Memory Barrier&#xff09;是在計算機體系結構中使用的一種同步機制&#xff0c;用于確保在多線程或多核處理器環境中&#xff0c;對共享內存的操作按照預期順序進行。它們通過強制在特定點執行一些指令來規定內存訪問的順序&#xff0c;并防止內存亂序執…

弱網對抗的策略有哪些?

在弱網環境下&#xff0c;數據傳輸可能會面臨丟包、延遲、抖動等問題&#xff0c;因此采取合適的弱網對抗策略對于確保數據傳輸的穩定性和可靠性至關重要。以下是一些常見的弱網對抗策略&#xff1a; 數據壓縮&#xff1a;使用壓縮算法如Gzip、Brotli等對數據進行壓縮&#xf…

Linux-vi/vim

vi是一個文本編輯器&#xff0c;用于撰寫文檔或開發程序 vim是vi的增強版&#xff0c;功能一致&#xff0c;可視化效果更好一些&#xff0c;去鼠標化&#xff0c;編輯更加方便&#xff0c;可定制化 vim編輯器是一個模式化文本編輯工具 vim有三種模式 編輯模式、插入模式和末…