动态规划(方案还原):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( ...
随机推荐
- asp.net mvc 实现记忆返回的功能
大体思路是在当前跳转链接追加一个参数memoryguid,以guid为key把查询query保存在cookie里,跳转的时候带走这个guid,回来的时候还带着,这样我们就能根据这个guid从cooki ...
- oracle 数据库关闭的的几种方式总结
shutdown的几种方式,shutdown abort的一些弊端有哪些 1.shutdown normal 正常方式关闭数据库. 2.shutdown immediate ...
- awr相关指标解析
awr相关指标解析 2016年11月11日 15:09
- 【转】 KVC/KVO原理详解及编程指南
原文地址:http://blog.csdn.net/wzzvictory/article/details/9674431 前言: 1.本文基本不讲KVC/KVO的用法,只结合网上的资料说说对这种技术的 ...
- jQuery Callback 方法
Callback 函数在当前动画 100% 完成之后执行. jQuery 动画的问题 许多 jQuery 函数涉及动画.这些函数也许会将 speed 或 duration 作为可选参数. 例子:$(& ...
- [转]一个备份MySQL数据库的简单Shell脚本
本文翻译自 iSystemAdmin 的 <A Simple Shell Script to Backup MySQL Database> Shell脚本是我们写不同类型命令的一种脚本,这 ...
- jq 图片裁剪
1.html <div class="jcropbox" style="display: none"> <img src="&quo ...
- Java反射与代理
Java反射机制与动态代理,使得Java更加强大,Spring核心概念IoC.AOP就是通过反射机制与动态代理实现的. 1 Java反射 示例: User user = new User( ...
- python3 读写excel
一直认为python3可以很快的实现很多简单的功能,今天要读excel表格数据,想来很简单,网上一搜,用xlrd即可,然后很多人给出了不同的版本,号称xlrd3,实际上官网一看,xlrd0.9.4兼容 ...
- DBCONN
package Ulike_servlet; //将该类保存到com.tools包中import java.sql.Connection;import java.sql.DriverManager;i ...