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. opencv 手写选择题阅卷 (三)训练分类器

    opencv 手写选择题阅卷 (三)训练分类器 1,分类器选择:SVM 本来一开始用的KNN分类器,但这个分类器目前没有实现保存训练数据的功能,所以选择了SVN分类器; 2,样本图像的预处理和特征提取 ...

  2. Contiki系统介绍

    本文内容来源为contiki英文介绍,自己为了学习,将其大致翻译成中文,以便了解. 欢迎转载,转载请注明来源,如果有什么翻译不合适的地方,请留言指出,相互交流学习. 介绍 Contiki是一个开放源码 ...

  3. 按按钮调用PHP function函数

    首先,请大家看一段HTML代码: <html> <head> </head> <body> <input type=button on_click ...

  4. 分类算法之贝叶斯(Bayes)分类器

    摘要:旁听了清华大学王建勇老师的 数据挖掘:理论与算法 的课,讲的还是挺细的,好记性不如烂笔头,在此记录自己的学习内容,方便以后复习.   一:贝叶斯分类器简介 1)贝叶斯分类器是一种基于统计的分类器 ...

  5. HTML5之 Microdata微数据

    - 为何需要微数据 长篇加累版牍,不好理解 微标记来标注其中内容,让其容易识辨 - RDFa Resource Description Framework http://www.w3.org/TR/m ...

  6. C++中执行windows指令

    执行windows指令: BOOL ExecDosCmd(]) { SECURITY_ATTRIBUTES sa; HANDLE hRead,hWrite; sa.nLength = sizeof(S ...

  7. 转 Linux命令及Linux终端的20个趣事

    https://linux.cn/article-2831-1.html 1. 命令:sl (蒸汽机车) 你可能了解 ‘ls’ 命令,并经常使用它来查看文件夹的内容.但是,有些时候你可能会拼写成 ‘s ...

  8. Delphi通过Map文件查找内存地址出错代码所在行

    一 什么是MAP文件 什么是 MAP 文件?简单地讲, MAP 文件是程序的全局符号.源文件和代码行号信息的唯一的文本表示方法,它可以在任何地方.任何时候使用,不需要有额外的程序进行支持.而且,这是唯 ...

  9. 《C和指针》 读书笔记 -- 第9章 字符串、字符和字节

    1.字符串以NUL结尾,但字符串长度不包括NUl字节. 2.复制字符串 char *strcpy(char *dst,char const *src); 3.连接字符串 char *strcat(ch ...

  10. 用minicom 产看 usb的串口

    1 用命令   sudo apt-get install minicom  安装 2 用 minicom -s 进行配置 往下选择  Seral port setup: 然后输入  A :选择自己的 ...