SRM588
250:
有n首歌每首歌有duration和tone,连续唱m首歌会消耗每首歌的duration以及相邻两首歌的tone的差的绝对值的和,给个T,问说在T时间内最对能唱多少歌。
将歌按tone排序后发现,只要枚举连续歌的最左和最右,这样产生的收尾的tone的绝对值的差的和是不变的,然后将中间的歌按duration从小到大唱,知道时间T消耗完毕。
500:
要发现访问若干room后获取到的钥匙的数量与访问的顺序是无关的,用dp(i, j)表示访问过i(i表示访问过的room的二进制状态压缩)后,手里拥有j把红钥匙的白钥匙最多的数量。
#include <iostream>
#include <vector>
#include <cstring>
#include <map>
using namespace std; typedef vector<int> VI; int dp[ << ][];
int num[ << ]; class KeyDungeonDiv1 {
private:
int n;
//map<int, int> dp_;
public:
KeyDungeonDiv1() {
memset(dp, -, sizeof(dp));
}
int get_dp(int i, int k) {
return dp[i][k];
/*
int idx = i * 131 + k;
if (dp_.find(idx) == dp_.end()) return -1;
else return dp_[idx];
*/
}
void set_dp(int i, int k, int v) {
dp[i][k] = v;
/*
int idx = i * 131 + k;
dp_[idx] = v;
*/
}
bool open_door(int& r, int& g, int& w, int dr, int dg) {
int need = ;
if (dr - r > ) need += (dr - r);
if (dg - g > ) need += (dg - g);
if (need <= w) {
r -= dr;
g -= dg;
if (r < ) {
w += r;
r = ;
}
if (g < ) {
w += g;
g = ;
}
return true;
} else {
return false;
}
}
int maxKeys(VI door_r, VI door_g, VI room_r, VI room_g, VI room_w, VI keys) {
int ans = keys[] + keys[] + keys[];
n = door_r.size();
memset(num, -, sizeof(num));
set_dp( << n, keys[], keys[]);
num[ << n] = keys[] + keys[] + keys[];
for (int i = ; i < ( << (n + )); i++) {
for (int k = ; k <= ; k++) {
if (get_dp(i, k) != -) {
for (int u = ; u < (n + ); u++) if ((i & ( << u)) == ) {
int w = get_dp(i, k);
int r = k;
int g = num[i] - w - r;
if (open_door(r, g, w, door_r[u], door_g[u])) {
if (num[i | ( << u)] == -) num[i | ( << u)] = r + g + w + room_r[u] + room_g[u] + room_w[u];
if (w + room_w[u] > get_dp(i | ( << u), r + room_r[u])) {
set_dp(i | ( << u), r + room_r[u], w + room_w[u]);
if (num[i | ( << u)] > ans) {
ans = num[i | ( << u)];
}
}
}
}
}
}
}
return ans;
}
};
SRM588的更多相关文章
随机推荐
- Eclipse JavaEE设置内置浏览器和外部浏览器
Eclipse JavaEE设置内置浏览器和外部浏览器 我们在使用Java EE版本的Eclipse开发Java Web程序时,Eclipse会有一个默认的内置浏览器查看网页的效果,如下图 但是内置浏 ...
- CICS日志---内存问题
Level 9 COCITOOL_XA: Connected! [2014-01-09 19:46:24.296834][22347888] Level 0 TestPerormence: GDAO ...
- apache重写字段详细说明
用Apache虚拟主机的朋友很多,apache提供的.htaccess模块可以为每个虚拟主机设定rewrite规则,这对网站SEO优化相当有用,同时也改善了用户体验.国内的虚拟机一般不提供.htacc ...
- Excel导入功能
一:前端 <t:dgToolBar title="Excel题库导入" icon="icon-search" onclick="question ...
- jquery.ajax中的ifModified参数的误解
原来以为ifModified是为了在AJAX请求是发送 If-Modified-Since头,让服务端返回304. 测试代码如下: $(function () { test(); window.set ...
- fill与memset的区别
fill 的头文件是<iostream> 命名空间是std: 在memset(a,0(-1),sizeof(a))全部初值定为0或-1时两者是没有多大区别; 但是在初值为其他值得时候就不同 ...
- 从 Typecho 自定义字段的调用代码看去
千呼万唤,Typecho 的"自定义字段"功能终于在 0.9 中出来了.然而,多数人还蒙在这样一个鼓里--该怎么在模板调用已经设置好的自定义字段呢?让我们从这里开始说下去: Typ ...
- Oracle 内核参数
安装Oracle的时候,可以参考Oracle 的安装文档,来设置相关内核参数的值,但是有些参数的值还是需要根据我们自己的情况来进行调整.注:不同系统的参数不同,本篇针对linux. 一.Linux 系 ...
- ubuntu下安装ffmpeg和X264
第一步:安装必要的库 $:-dev libtheora-dev libx11-dev zlib1g-dev 第二步:安装SDL(否则可能编译不出ffplay) $:-dev $:-dev libsdl ...
- MVC视图引擎
1.视图引擎:把视图解析成浏览器可执行的html代码 2.aspx视图: <%=表达式%>: <% C#代码段 %>: 3.razor视图: @(表达式):@ViewData[ ...