动态规划(方案还原):SGU 104 Little shop of flowers
花店橱窗布置问题
时间限制:3000 ms
问题描述(Problem)
假设你想以最美观的方式布置花店的橱窗,你有F束花,每束花的品种都不一样,同时,你至少有同样数量的花瓶,被按顺序摆成一行。花瓶的位置是固定的,并从
左至右,从1至V顺序编号,V是花瓶的数目,编号为1的花瓶在最左边,编号为V的花瓶在最右边。花束则可以移动,并且每束花用1至F的整数唯一标识。标识
花束的整数决定了花束在花瓶中排列的顺序,即如果i<j,则花束i必须放在花束j左边的花瓶中。
例如,假设社鹃花的标识数为1,秋海棠的标识数为2,康乃馨的标识数为3,所有的花束在放入花瓶时必须保持其标识数的顺序,即:杜鹃花必须放在秋海棠左边
的花瓶中,秋海棠必须放在康乃馨左边的花瓶中。如果花瓶的数目大于花束的数目,则多余的花瓶必须空置,每个花瓶中只能放一柬花。
每一个花瓶的形状和颜色也不相同,因此,当各个花瓶中放入不同的花束时,会产生不同的美学效果,并以美学值(一个整数)来表示。空置花瓶的美学值为零。在上述例子中,花瓶与花束的不同搭配所具有的美学值,可以用下面式样的表格来表示。
花瓶 |
||||||
1 |
2 |
3 |
4 |
5 |
||
花束 |
1.杜鹃花 |
7 |
23 |
-5 |
-24 |
16 |
2.秋海棠 |
5 |
21 |
-4 |
10 |
23 |
|
3.康乃馨 |
-21 |
5 |
-4 |
-20 |
20 |
例如,根据上表,社鹃花放在花瓶2中,会显得非常好看;但若放在花瓶4中则显得很难看。
为取得最佳美学效果,你必须在保持花束顺序的前提下,使花束的摆放取得最大的美学值,如果具有最大美学值的摆放方式不止一种,则其中任何一种摆放方式都可以接受,但你只可输出其中一种摆放方式。
假设条件(Asumption)
1≤F≤100,其中F为花束的数量,花束编号从1至F.
F≤V≤100,其中V是花瓶的数量。
-50≤Aij≤50,其中Aij小是花束i在花瓶j中时的美学值。
输入(Input)
输入文件是正文文件(text file),文件名是flower.inp。
第一行包含两个数:F,V
随后的F行中,每行包含V个整数,Aij即为输入文件中第(I+1)行中的第j个数。
输出(Input)
输出文件必须是名为f1ower.out的正文文件,文件应包含两行:
第一行是程序所产生摆放方式的美学值。
第二行必须用F个数表示摆放方式,即该行的第k个数表示花束K所在的花瓶的编号。
例子
Flower.inp:
3 5
7 23 –5 –24 16
5 21 –4 10 23
-21 5 –4 –20 20
Flower.out :
53
2 4 5
真是哔了狗了,这道题在好多OJ上都被阉割了,没有方案还原的那一问了。
终于找到SGU,还是保持了原问题。
水题直接贴代码!
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
using namespace std;
const int maxf=,maxv=;
int val[maxf][maxv];
int dp[maxf][maxv][];
int ans[maxf];
int main()
{
int F,V;
scanf("%d%d",&F,&V);
for(int i=;i<=F;i++)
for(int j=;j<=V;j++)
scanf("%d",&val[i][j]); for(int i=;i<=F;i++){
int maxp=i-;
for(int j=i;j<=V;j++)
{
dp[i][j][]=dp[i-][maxp][]+val[i][j];
dp[i][j][]=maxp;
if(dp[i-][j][]>dp[i-][maxp][])
maxp=j;
}
} int maxp=-;
for(int i=F;i<=V;i++)
if(maxp==-||dp[F][i][]>dp[F][maxp][])
maxp=i; printf("%d\n",dp[F][maxp][]); for(int i=F;i>=;i--){
ans[i]=maxp;
maxp=dp[i][maxp][];
} for(int i=;i<=F;i++)
printf("%d ",ans[i]);
printf("\n");
return ;
}
动态规划(方案还原):SGU 104 Little shop of flowers的更多相关文章
- sgu 104 Little shop of flowers 解题报告及测试数据
104. Little shop of flowers time limit per test: 0.25 sec. memory limit per test: 4096 KB 问题: 你想要将你的 ...
- SGU 104. Little shop of flowers (DP)
104. Little shop of flowers time limit per test: 0.25 sec. memory limit per test: 4096 KB PROBLEM Yo ...
- SGU 104 Little shop of flowers【DP】
浪(吃)了一天,水道题冷静冷静.... 题目链接: http://acm.sgu.ru/problem.php?contest=0&problem=104 题意: 给定每朵花放在每个花盆的值, ...
- sgu 104 Little Shop of Flowers
经典dp问题,花店橱窗布置,不再多说,上代码 #include <cstdio> #include <cstring> #include <iostream> #i ...
- SGU 104
104. Little shop of flowers time limit per test: 0.25 sec. memory limit per test: 4096 KB PROBLEM Yo ...
- 快速切题 sgu104. Little shop of flowers DP 难度:0
104. Little shop of flowers time limit per test: 0.25 sec. memory limit per test: 4096 KB PROBLEM Yo ...
- POJ-1157 LITTLE SHOP OF FLOWERS(动态规划)
LITTLE SHOP OF FLOWERS Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 19877 Accepted: 91 ...
- [POJ1157]LITTLE SHOP OF FLOWERS
[POJ1157]LITTLE SHOP OF FLOWERS 试题描述 You want to arrange the window of your flower shop in a most pl ...
- 【SGU 104】Little shop of flowers
题意 每个花按序号顺序放到窗口,不同窗口可有不同观赏值,所有花都要放上去,求最大观赏值和花的位置. 分析 dp,dp[i][j]表示前i朵花最后一朵在j位置的最大总观赏值. dp[i][j]=max( ...
随机推荐
- window.showModalDialog()复制内容
ShowModalDialog 打开的 页面上加入个 <span id="mySpan" name="mySpan" contentEditable=&q ...
- 微软企业库Microsoft Enterprise Library的相关文章链接
微软企业库4.1学习笔记 http://blog.csdn.net/anyqu/article/category/1228691/3 黄聪:Enterprise Library 5.0 系列教程 ww ...
- 搞一个app需要多久?
//转载文章,看后有感 我有些尴尬地拿着水杯,正对面坐着来访的王总,他是在别处打拼的人,这几年据说收获颇丰,见移动互联网如火如荼,自然也想着要进来干一场,尽管王总从事的行当也算跟IT沾边,但毕竟太长时 ...
- iOS远程消息推送
iOS 推送基础知识 Apple 使用公共密钥数字证书对来自 iOS 应用程序的推送请求进行身份验证,所以您首先需要创建身份验证密钥,并向 Apple 注册它们.我将在下一节中花相当长的篇幅来直接介绍 ...
- 十五、C# 使用查询表达式的LINQ
使用查询表达式的LINQ 本章介绍了一种新的语法,查询表达式. 1.查询表达式概述 2.特点:投射 筛选 排序 Let 分组 3.作为方法调用 标准查询运算符所实现的查询在功能上 ...
- js做全选,用一个checkbox复选框做多个checkbox复选框的全选按钮,有一个复选框未被选择时,全选按钮的checked就为false
用一个checkbox复选框做多个checkbox复选框的全选按钮,有一个复选框未被选择时,全选按钮的checked就为false,当所有checkbox都被选中时,全选按钮也被选中. 详解: 有两种 ...
- Python:函数定义
#!/usr/bin/python3 #函数 def add(a,b): return a+b print("add(2,5) = ",add(2,5)) def add2(a,b ...
- Strut2 采用token机制防御CSRF同时也可以防止表单重复提交
一 未配置Struts2 token的情况下测试 1.从表单提交数据,可以从下图看出,快速点击保存按钮,请求提交了两次 2.检查post提交的数据中未含有token参数 3.查看数据列表,有重复数据 ...
- IOS DLNA PlatinumKit库的使用
前段时间进行了IOS DLNA的开发,使用的是PlatinumKit库.网上查了很多资料都未果,经过自己的摸索,遂将如何使用PlatinumKit进行DLNA的开发分享给大家. 1.PlatinumK ...
- Java学习----集合框架总结
集合框架总结: Collection接口: Set接口: HashSet//对象必须实现hashCode方法,元素没有顺序呢,效率比LinkedHashSet高 LinkedHashSet//是Has ...