最近做了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)的更多相关文章

  1. [BZOJ3535][Usaco2014 Open]Fair Photography

    [BZOJ3535][Usaco2014 Open]Fair Photography 试题描述 FJ's N cows (1 <= N <= 100,000) are standing a ...

  2. BZOJ3540: [Usaco2014 Open]Fair Photography

    3540: [Usaco2014 Open]Fair Photography Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 72  Solved: 29 ...

  3. bzoj 3540: [Usaco2014 Open]Fair Photography

    3540: [Usaco2014 Open]Fair Photography Description FJ's N cows (2 <= N <= 100,000) are standin ...

  4. poj3274 Gold Balanced Lineup(HASH)

    Description Farmer John's N cows (1 ≤ N ≤ 100,000) share many similarities. In fact, FJ has been abl ...

  5. Gold Balanced Lineup(hash)

    http://poj.org/problem?id=3274 ***** #include <stdio.h> #include <iostream> #include < ...

  6. P3105 [USACO14OPEN]公平的摄影Fair Photography

    题意翻译 在数轴上有 NNN 头牛,第 iii 头牛位于 xi(0≤xi≤109)x_i\:(0\le x_i\le 10^9)xi​(0≤xi​≤109) .没有两头牛位于同一位置. 有两种牛:白牛 ...

  7. Fair Photography

    题目大意: 给出直线上N个点的位置和颜色(0或1),求最大的区间,使得区间内0的个数大于等于1的个数且0的个数减去1的个数为偶数. 解题过程: 1.先贴个lsdsjy大牛的线段树的做法:http:// ...

  8. [Usaco2014 Open Gold ]Cow Optics (树状数组+扫描线/函数式线段树)

    这道题一上手就知道怎么做了= = 直接求出原光路和从目标点出发的光路,求这些光路的交点就行了 然后用树状数组+扫描线或函数式线段树就能过了= = 大量的离散+模拟+二分什么的特别恶心,考试的时候是想到 ...

  9. 解题:USACO14OPEN Fair Photography

    题面 有点像JRY的那道序列题,大概是统计题的经典套路? 先说无修改的:将白奶牛记为$-1$,花奶牛记为$1$,然后做前缀和统计某个前缀和$sum$第一次出现的位置,之后再出现就统计答案.对于修改(将 ...

随机推荐

  1. git 常用命令--Linus Torvalds

    1.git log 显示仓库的历史记录,默认显示所有记录, 1)git log -m,显示最近的几次提交,, 2)git log --pretty=oneline  显示提交hash和注释 -p 按补 ...

  2. Vector类

    /* * Vector的特有功能 * * Vector出现较早,比集合更早出现 * * 1:添加功能 * public void addElement(Object obj);//用add()替代 * ...

  3. Struts2标签遍历List<Map<String,String>>

    <s:if test="resultList != null && resultList.size() > 0"> <s:iterator  ...

  4. pku2104

    传送门:http://poj.org/problem?id=2104 题目大意:给定一个长度为N的数组{A[i]},你的任务是解决Q个询问.每次询问在A[l], A[l+1], ...... , A[ ...

  5. centos5.5开机自动启动服务的方法

    *** chkconfig --list 查看所有的***chkconfig --list smb 查看指定的输出的结果:httpd           0:off   1:off   2:off   ...

  6. YII 1.0 缓存使用

    在main.php的组件components中配置设置添加缓存 'cache'=>array( 'class' => 'system.caching.CFileCache' ), 也就是f ...

  7. NOIP 提高组必会!(转)

    1.排序算法(快排.选择.冒泡.堆排序.二叉排序树.桶排序)2.DFS/BFS 也就是搜索算法,剪枝务必要学! 学宽搜的时候学一下哈希表!3.树 ①遍历 ②二叉树 ③二叉排序树(查找.生成.删除) ④ ...

  8. 在Winfrom下实现类似百度、Google搜索自能提示功能

    前记:数据源来自页面的一个ComboBox的数据源List<Contract>集合 页面放置一个TextBox(搜索框).ListBox(显示搜索出来的数据),ListBox位置位于Tex ...

  9. 开箱即用 - Grunt合并和压缩 js,css 文件

    js,css 文件合并与压缩 Grunt 是前端自动化构建工具,类似webpack. 它究竟有多强悍,请看它的 介绍. 这里只演示如何用它的皮毛功能:文件合并与压缩. 首先说下js,css 合并与压缩 ...

  10. POJ1077&&HDU1043(八数码,IDA*+曼哈顿距离)

    Eight Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 30127   Accepted: 13108   Special ...