[Usaco2014 Open]Gold Fair Photography(hash)
最近做了usaco2014 open的金组,果然美帝的题还是没有太简单啊QAQ,被每年的月赛骗了QAQ
不过话说官方题解真心棒(虽然英文的啃得好艰难,我英语渣你们别鄙视我= =),标程超级优美QAQ
按照标程打,学到了好多STL的用法= =(没办法,我c++底子弱)
这道题嘛,可以发现对于每个区间,只要左边界确定,可能的集合就一共只有8种了
考虑前缀和,发现若L~R为可行解,则对于所有种类的牛,有S[R]-S[L]=K或0
如何防止枚举K,可以发现在该集合中B的s[L][bi]减去s[L][b0]就行了
那么就hash,枚举集合B,求出hash值,直接做就行了
CODE:(直接贴标程了,Map真的用的是神出鬼没啊QAQ)
#include <iostream>
#include <vector>
#include <algorithm>
#include <cstring>
#include <cstdio>
#include <cassert>
#include <map> using namespace std; #define MAXN 100010
#define GROUPS 8 int MB[MAXN][GROUPS];
int MF[MAXN][GROUPS];
int PS[MAXN][GROUPS]; int main() {
freopen("fairphoto.in", "r", stdin);
freopen("fairphoto.out", "w", stdout); int N, K; cin >> N >> K;
vector<pair<int, int> > A(N);
for(int i = 0; i < N; i++) {
cin >> A[i].first >> A[i].second;
A[i].second--;
}
sort(A.begin(), A.end()); /* Construct backstep masks */
for(int i = 0; i < GROUPS; i++) {
MB[0][i] = 1 << A[0].second;
}
for(int i = 1; i < N; i++) {
int bt = 1 << A[i].second; MB[i][0] = bt;
for(int j = 1; j < GROUPS; j++) {
if(MB[i - 1][j] & bt) {
MB[i][j] = MB[i - 1][j];
} else {
MB[i][j] = bt | MB[i - 1][j - 1];
}
}
} /* Construct forward step masks */
for(int i = 0; i < GROUPS; i++) {
MF[N - 1][i] = 1 << A[N - 1].second;
}
for(int i = N - 2; i >= 0; i--) {
int bt = 1 << A[i].second; MF[i][0] = bt;
for(int j = 1; j < GROUPS; j++) {
if(MF[i + 1][j] & bt) {
MF[i][j] = MF[i + 1][j];
} else {
MF[i][j] = bt | MF[i + 1][j - 1];
}
}
} /* Construct partial sums */
for(int i = 0; i < N; i++) {
memcpy(PS[i + 1], PS[i], sizeof(PS[i]));
++PS[i + 1][A[i].second];
} int result = -1;
for(int j = K - 1; j < GROUPS; j++) {
vector<int> V(1 + GROUPS);
map<vector<int>, int> cost_map; /* Compute the earliest starts for given masks
* and normalized partial sums. */
for(int i = N - 1; i >= 0; i--) {
int base = -1;
int m = V[GROUPS] = MF[i][j];
if(__builtin_popcount(m) <= j) continue;
for(int k = 0; k < GROUPS; k++) {
if(m & 1 << k) {
if(base == -1) {
base = PS[i][k];
}
V[k] = PS[i][k] - base;
} else {
V[k] = PS[i][k];
}
}
cost_map[V] = A[i].first;
} /* Find best start points for each ending position. */
for(int i = 0; i < N; i++) {
int base = -1;
int m = V[GROUPS] = MB[i][j];
if(__builtin_popcount(m) <= j) continue;
for(int k = 0; k < GROUPS; k++) {
if(m & 1 << k) {
if(base == -1) {
base = PS[i + 1][k];
}
V[k] = PS[i + 1][k] - base;
} else {
V[k] = PS[i + 1][k];
}
} map<vector<int>, int>::iterator it = cost_map.find(V);
if(it != cost_map.end() && it->second < A[i].first) {
result = max(result, A[i].first - it->second);
}
}
} cout << result << endl;
return 0;
}
[Usaco2014 Open]Gold Fair Photography(hash)的更多相关文章
- [BZOJ3535][Usaco2014 Open]Fair Photography
[BZOJ3535][Usaco2014 Open]Fair Photography 试题描述 FJ's N cows (1 <= N <= 100,000) are standing a ...
- BZOJ3540: [Usaco2014 Open]Fair Photography
3540: [Usaco2014 Open]Fair Photography Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 72 Solved: 29 ...
- bzoj 3540: [Usaco2014 Open]Fair Photography
3540: [Usaco2014 Open]Fair Photography Description FJ's N cows (2 <= N <= 100,000) are standin ...
- poj3274 Gold Balanced Lineup(HASH)
Description Farmer John's N cows (1 ≤ N ≤ 100,000) share many similarities. In fact, FJ has been abl ...
- Gold Balanced Lineup(hash)
http://poj.org/problem?id=3274 ***** #include <stdio.h> #include <iostream> #include < ...
- P3105 [USACO14OPEN]公平的摄影Fair Photography
题意翻译 在数轴上有 NNN 头牛,第 iii 头牛位于 xi(0≤xi≤109)x_i\:(0\le x_i\le 10^9)xi(0≤xi≤109) .没有两头牛位于同一位置. 有两种牛:白牛 ...
- Fair Photography
题目大意: 给出直线上N个点的位置和颜色(0或1),求最大的区间,使得区间内0的个数大于等于1的个数且0的个数减去1的个数为偶数. 解题过程: 1.先贴个lsdsjy大牛的线段树的做法:http:// ...
- [Usaco2014 Open Gold ]Cow Optics (树状数组+扫描线/函数式线段树)
这道题一上手就知道怎么做了= = 直接求出原光路和从目标点出发的光路,求这些光路的交点就行了 然后用树状数组+扫描线或函数式线段树就能过了= = 大量的离散+模拟+二分什么的特别恶心,考试的时候是想到 ...
- 解题:USACO14OPEN Fair Photography
题面 有点像JRY的那道序列题,大概是统计题的经典套路? 先说无修改的:将白奶牛记为$-1$,花奶牛记为$1$,然后做前缀和统计某个前缀和$sum$第一次出现的位置,之后再出现就统计答案.对于修改(将 ...
随机推荐
- thinkphp ,进行关联模型的时候出现的问题,版本是3.2
看的后盾网络视频,里面操作的是3.1. 我用的是onethink,基于3.2. 在关联模式的操作时.主要是user role role_user 3个张表 视频中可以操作,但是本地操作出现问题. ...
- 一段神奇的代码-关于PHP字符变量奇怪现象的解释
首先神奇的PHP是支持字符数据类型的,有同学就写了这样一段代码: for ($c = 'a'; $c <= 'z'; $c++) { echo $c . ' '; } 然而结果却不是他想要的a到 ...
- 关于ThreadLocal和一般的线程同步的详细解释
http://blog.csdn.net/lufeng20/article/details/24314381
- 在Spring MVC Controller的同一个方法中,根据App还是WEB返回JSON或者HTML视图。
如有高见,欢迎交流! 最近在做一个web的项目,web版已经开发完毕,现在正在进行手机APP的开发,开发中遇到一个问题: 就是web版和app版都有登录功能,本想着是分别走不同的URL,实际开发的时候 ...
- 判断activity是否显示在界面上
boolean result = false; ActivityManager am = (ActivityManager) context .getSystemService(Context.ACT ...
- inheritprototype原型继承封装及综合继承最简实例
1.inheritprototype.js ;(function(){ var s = { inheritObject:function(o){//对象继承封装 ...
- js原生继承之——原型式继承实例
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8&qu ...
- swift中标签的使用
1,标签的创建 1 2 3 4 5 6 7 8 9 10 import UIKit class ViewController: UIViewController { override func ...
- 使用Flex4容器若干技巧
本文适用于正在寻找使用Flex 4容器和布局的快速参考指南的开发人员. 尽管这不一定是一个复杂问题,但这似乎是许多开发人员的挫折的来源,特别是对于那些Flex刚刚入门的开发人员. 当开发人员不知道如何 ...
- windows10 subsystem(bash) 如何使用jupter notebook
按照传统惯例,应该映射端口jupyter notebook --port=15000,然后用浏览器开http://localhost:15000/ 但是当你运行python的时候,居然发现kernel ...