花店橱窗布置(洛谷P1854)(动态规划)
生活随笔
收集整理的這篇文章主要介紹了
花店橱窗布置(洛谷P1854)(动态规划)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
傳送門
文章目錄
- 解析
- 問題
- 代碼
解析
一道很正常的動態規劃
dp[i][j]表示到第j個花瓶放了第j朵花的dp最優值
注意:是嚴格使第i朵放在j瓶
找到最優解遞歸輸出即可
問題
又是初始化的問題!!!
一開始把dp賦值成負無窮時落掉了j=0的一行
但到0個花瓶放了i朵花顯然也是不合法的(i不等于0時)
導致出錯
以后動態規劃一定要重視初始化!!!
代碼
#include<bits/stdc++.h> using namespace std; #define ll long long const int N=105; int v[N][N]; int dp[N][N];//j瓶放到第i朵 int n,m; int a,b,c; int pre[N][N]; void print(int k,int pl){if(k==0) return;print(k-1,pre[k][pl]);printf("%d ",pl); } int main(){scanf("%d%d",&n,&m);for(int i=1;i<=n;i++){dp[i][0]=-2e9;for(int j=1;j<=m;j++) scanf("%d",&v[i][j]),dp[i][j]=-2e9;}for(int j=0;j<=m;j++) dp[0][j]=0;for(int j=1;j<=m;j++){for(int i=1;i<=n;i++){for(int k=i-1;k<j;k++){if(dp[i][j]<dp[i-1][k]+v[i][j]){dp[i][j]=dp[i-1][k]+v[i][j];pre[i][j]=k;}}}}int ans=-2e9,pl;for(int j=1;j<=m;j++){if(ans<dp[n][j]){ans=dp[n][j];pl=j;}}printf("%d\n",ans);print(n,pl);return 0; } /* 3 5 7 23 -5 -24 16 5 21 -4 10 23 -21 5 -4 -20 20 */總結
以上是生活随笔為你收集整理的花店橱窗布置(洛谷P1854)(动态规划)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 判断整除(opj)(动态规划)
- 下一篇: 斯莫格推出苹果 iPhone 15 Pr