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的更多相关文章

随机推荐

  1. hibernate的id生成策略

    欢迎转载,请注明出处http://www.cnblogs.com/shizhongtao/p/3436523.html 一.xml配置方式的id生成 <id name="id" ...

  2. 正文字体大小:大 中 小 解决configure: error: Cannot find libmysqlclient under /usr

    今天在64位centos5.6系统上编译PHP5.2.17报错 checking for MySQL support... yes, shared checking for specified loc ...

  3. String.Format数字格式化输出 {0:N2} {0:D2} {0:C2

    //格式为sring输出 //   Label1.Text = string.Format("asdfadsf{0}adsfasdf",a); //   Label2.Text = ...

  4. Pandas简易入门(二)

    目录:     处理缺失数据     制作透视图     删除含空数据的行和列     多行索引     使用apply函数   本节主要介绍如何处理缺失的数据,可以参考原文:https://www. ...

  5. .NET基础之自定义泛型

    在.NET中泛型使用非常频繁,在控制台应用程序中,默认的引入了System.Collection.Generics名称空间,其中就提供了我们经常使用的泛型:List<T>和Dictiona ...

  6. Android笔记——Bitmap自动取色(纯搬运)

    2015/6/12更新:发现一个更好的,带demo https://github.com/MichaelEvans/ColorArt 说明: 这个是一个老外写的自动自动从bitmap中取主色与第二主色 ...

  7. make问题:make[1] entering directory

    执行make distclean命令.

  8. 【socket】高级用法-异步

    ReceiveAsync ReceiveFromAsync ReceiveMessageFromAsync

  9. [译] ASP.NET 生命周期 – ASP.NET 请求生命周期(三)

    使用特殊方法处理请求生命周期事件 为了在全局应用类中处理这些事件,我们会创建一个名称以 Application_ 开头,以事件名称结尾的方法,比如 Application_BeginRequest.举 ...

  10. mybatis显示sql语句 log4j.properties配置文件

    log4j.properties配置如下: 将ibatis log4j运行级别调到DEBUG可以在控制台打印出ibatis运行的sql语句,方便调试: ### 设置Logger输出级别和输出目的地 # ...