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. Paxos算法

    Paxos算法是分布式系统中常用的一个保持系统一致性的算法,由美国计算机科学家Leslie B. Lamport提出.原文链接. 今天特意学习了一下Paxos的原理,为防忘记,记录下来.(看了的东西没 ...

  2. ubuntu后台配置无线网络

    一.静态配置: 1.编辑 /etc/network/interfaces: auto loiface lo inet loopback auto wlan0iface wlan0 inet stati ...

  3. JasperReport原理解析之(一)

    1. [加载原始文件]有iReport生成jrxml文件后,由jasperreport包中的类JRXml文件 加载和解析 jrxml文件. 文件解析后生成  JasperDesign对象. Jaspe ...

  4. margin的BUG(2)

    继续上一次的学习,这次又发现了margin的第二个bug.既当同时对两个相邻的div盒子设置margin时,他们之间的间隙不能正常显示. 具体表述为:先建立两个div1和div2 <div cl ...

  5. 基于css3新属性transform及原生js实现鼠标拖动3d立方体旋转

    基于css3新属性transform,实现3d立方体的旋转 通过原生JS,点击事件,鼠标按下.鼠标抬起和鼠标移动事件,实现3d立方体的拖动旋转,并将旋转角度实时的反应至界面上显示 实现原理:通过获取鼠 ...

  6. Android:启动引导页实现

    前言 基本上现在所有的应用都会有一个欢迎界面,在欢迎界面对应用做一个整体的介绍,然后在跳入到主界面,这次要说的这个引导页就是带翻页的引导页.效果如下所示

  7. javascript的setTimeout以及setInterval休眠问题。

    前端码农们在做项目中时候,必定不可少的需要做到轮播效果.但是有些特殊的需求,比如: 需要做到第一个容器内容轮播滚动之后,第二个容器内部再轮播滚动,再第三个容器内容轮播滚动. 这时候我的一开始的思路是: ...

  8. Spark Streaming揭秘 Day11 Receiver Tracker的具体实现

    Spark Streaming揭秘 Day11 Receiver Tracker的具体实现 ReceiverTracker是运行在Driver上Receiver管理程序,今天让我们深入学习一下. 核心 ...

  9. Linux下mail/mailx命令发送邮件

    最近看到项目中经常会用mail/mailx命令发送由java程序生成的report,比较新鲜.下面就简单介绍下mail/mailx命令用法.本文以mail命令举例(mail/mailx)效果都是一样的 ...

  10. Ubuntu下Sublime Text 3无法输入中文的解决方案

    1. 保存下面的代码到文件sublime_imfix.c中: /* * sublime-imfix.c * Use LD_PRELOAD to interpose some function to f ...