nefu1130Attack monsters【平行四邊形優化石子合併】
//題中明確說了給定的不一定是有序的!!
<span style="background-color: rgb(255, 255, 255);"></span> #include <iostream>
#include <string.h>
#include <stdio.h>
#include<algorithm>
using namespace std;
const int INF = 1 << 30;
const int N = 1005;
int dp[N][N];
int p[N][N];
int sum[N];
int n;
int getMinval()
{
for(int i=1; i<=n; i++)
{
dp[i][i] = 0;
p[i][i] = i;
}
for(int len=1; len<n; len++)
{
for(int i=1; i+len<=n; i++)
{
int end = i+len;
int tmp = INF;
int k = 0;
for(int j=p[i][end-1]; j<=p[i+1][end]; j++)
{
if(dp[i][j] + dp[j+1][end] + sum[end] - sum[i-1] < tmp)
{
tmp = dp[i][j] + dp[j+1][end] + sum[end] - sum[i-1];
k = j;
}
}
dp[i][end] = tmp;
p[i][end] = k;
}
}
return dp[1][n];
}
int main()
{
// freopen("cin.txt","r",stdin);
int m;
while(scanf("%d%d",&n,&m)!=EOF)
{
if(n==0&&m==0) break;
sum[0] = 0;
for(int i=1; i<=n; i++)
{
int val;
scanf("%d",&sum[i]);
//= sum[i-1] + val;
}
sum[++n]=m;
sort(sum+1,sum+1+n);
printf("%d\n",getMinval());
}
return 0;
}
相關文章
- 石子合併
- CSS 平行四邊形導航選單CSS
- 四邊形不等式優化DP優化
- 【區間dp】石子合併
- 用CSS實現三角形和平行四邊形CSS
- 用 CSS 實現三角形與平行四邊形CSS
- 強大的CSS:實現平行四邊形佈局效果CSS
- 利用transform skewX製作平行四邊形導航選單ORM
- css3實現平行四邊形程式碼例項CSSS3
- CSS3繪製平行四邊形程式碼例項CSSS3
- 區間dp 合併石子問題
- CSS3實現的平行四邊形程式碼例項CSSS3
- 如何使用C++語言列印一個平行四邊形 - NOIP基礎C++
- 二叉搜尋樹 [四邊形不等式優化區間dp]優化
- 四邊形輔助線做法
- CSS 外邊距合併CSS
- BestCoder-四條邊是否能組成四邊形
- 段合併優化及注意事項優化
- 一次UnionAll的合併優化優化
- MySQL樹形遍歷(四)--程式碼優化MySql優化
- 石子合併問題 (樸素區間DP&&GarsiaWachs演算法)演算法
- table 設定合併邊框
- (四)Java高併發秒殺API之高併發優化JavaAPI優化
- SQL優化一則:取消檢視合併SQL優化
- 優化C++程式碼(3):常量合併優化C++
- 浮動定位(BFC、邊距合併)
- Spark優化之小檔案是否需要合併?Spark優化
- 前端效能優化 --- 資源合併與壓縮前端優化
- MySQL 優化之 index_merge (索引合併)MySql優化Index索引
- 優化 RequireJS 專案(合併與壓縮)優化UIJS
- CSS-盒子模型-邊距合併CSS模型
- 單匝不同形狀的線圈(四邊形)
- 四邊形不等式 & 決策單調性
- 前端面試必備——外邊距合併前端面試
- Java通過Fork/Join來優化平行計算Java優化
- 視覺化學習:利用向量判斷多邊形邊界視覺化
- iOS 圖形效能優化iOS優化
- 遊戲圖形批量渲染及優化:Unity靜態合批技術遊戲優化Unity