USACO 2017 US Open
只会做T1,FallDream T2 n^2暴力AC,太强啦。
T1.Modern Art
题目大意:有一个n*n的矩阵,一开始都是0,你有n^2种颜色,编号1到n^2,每次可以选出一种颜色涂满一个子矩阵(如果已涂则覆盖),每种颜色有且涂一次,给定最终矩阵的颜色,问有几种颜色可能是第一个涂上去的。(n<=1000)
思路:我们把最终每种颜色的最左最右最上最下当作这种颜色的边界,如果一种颜色的某个格子在超过1个边界内(即在除了自己颜色所在的边界的边界),那么这种颜色不可能是第一个涂的,二维前缀和解决即可,复杂度O(n^2)。
#include<cstdio>
#include<algorithm>
#include<vector>
using namespace std;
inline int read()
{
int x;char c;
while((c=getchar())<''||c>'');
for(x=c-'';(c=getchar())>=''&&c<='';)x=(x<<)+(x<<)+c-'';
return x;
}
#define MN 1000
vector< pair<int,int> > v[MN*MN+];
int f[MN+][MN+];
int main()
{
freopen("art.in","r",stdin);
freopen("art.out","w",stdout);
int n=read(),i,j,x,cnt=-,x0,y0,x1,y1;
for(i=;i<=n;++i)for(j=;j<=n;++j)if(x=read())
{
if(!v[x].size())++cnt;
v[x].push_back(make_pair(i,j));
}
if(!cnt)return *printf("%d",n*n-);
for(i=;i<=n*n;++i)if(v[i].size())
{
x0=y0=;x1=y1=;
for(j=;j<v[i].size();++j)
x0=min(x0,v[i][j].first),y0=min(y0,v[i][j].second),
x1=max(x1,v[i][j].first),y1=max(y1,v[i][j].second);
++f[x0][y0];--f[++x1][y0];--f[x0][++y1];++f[x1][y1];
}
for(i=;i<=n;++i)for(j=;j<=n;++j)f[i][j]+=f[i-][j]+f[i][j-]-f[i-][j-];
for(i=,cnt=;i<=n*n;++i)
{
for(j=;j<v[i].size();++j)
if(f[v[i][j].first][v[i][j].second]>)break;
if(j==v[i].size())++cnt;
}
printf("%d",cnt);
fclose(stdin);fclose(stdout);return ;
}
T2.Switch Grass
题目大意:给定一张n个点m条边的无向图,边有边权,点有颜色,q次操作,每次操作修改一个点的颜色并询问当前图中最近的两个颜色不同点的距离。(n,m,q<=200,000)
思路:首先最近的两个颜色不同点一定是相邻的点,并且一定都在这张图的最小生成树的一条边上(如果走多条边或者非最小生成树边,都容易证明必然有更优解)。先找出最小生成树,随便定个根,我们维护每个点连向他儿子的答案,可以用3种堆维护,第一种每个点对儿子的每种颜色都建一个,维护这种颜色中最近的儿子,第二种每个点建一个,维护这个点到儿子中最近的颜色和次近的颜色(若最近的颜色与该节点颜色相同则取次近作为答案),第三种维护各个点的答案,每次修改依次更新父亲的堆和答案,再更新一下自己的答案,总复杂度O(nlogn)。懒得打堆都用set代替了,结果T了一个点,发现存答案的堆可以用线段树代替,然后就过了。
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<set>
#include<map>
using namespace std;
inline int read()
{
int x;char c;
while((c=getchar())<''||c>'');
for(x=c-'';(c=getchar())>=''&&c<='';)x=(x<<)+(x<<)+c-'';
return x;
}
#define MN 200000
#define N 262144
#define INF 0x7FFFFFFF
#define p(x,y) make_pair(x,y)
struct Edge{int x,y,w;}E[MN+];
bool cmp(Edge a,Edge b){return a.w<b.w;}
struct edge{int nx,t,w;}e[MN*+];
int f[MN+],h[MN+],en,c[MN+],fa[MN+],tf[MN+],cnt,t[N*+];
set<pair<int,int> >stc[MN*+],stf[MN+];
set<pair<int,int> >::iterator it;
map<int,int> mp[MN+];
int gf(int k){return f[k]?f[k]=gf(f[k]):k;}
inline void ins(int x,int y,int w)
{
e[++en]=(edge){h[x],y,w};h[x]=en;
e[++en]=(edge){h[y],x,w};h[y]=en;
}
inline void change(int k,int x){for(t[k+=N]=x;k>>=;)t[k]=min(t[k<<],t[k<<|]);}
void dfs(int x)
{
int i,v;
stf[x].insert(p(INF,));
for(i=h[x];i;i=e[i].nx)if(e[i].t!=fa[x])
{
fa[e[i].t]=x;tf[e[i].t]=e[i].w;dfs(e[i].t);
if(v=mp[x][c[e[i].t]])stf[x].erase(p(stc[v].begin()->first,c[e[i].t]));
else stc[v=mp[x][c[e[i].t]]=++cnt].insert(p(INF,));
stc[v].insert(p(e[i].w,e[i].t));
stf[x].insert(p(stc[v].begin()->first,c[e[i].t]));
}
it=stf[x].begin();if(it->second==c[x])++it;
change(x,it->first);
}
void renew(int x,int z)
{
if(fa[x])
{
int v=mp[fa[x]][c[x]];
stf[fa[x]].erase(p(stc[v].begin()->first,c[x]));
stc[v].erase(p(tf[x],x));
stf[fa[x]].insert(p(stc[v].begin()->first,c[x]));
if(v=mp[fa[x]][z])stf[fa[x]].erase(p(stc[v].begin()->first,z));
else stc[v=mp[fa[x]][z]=++cnt].insert(p(INF,));
stc[v].insert(p(tf[x],x));
stf[fa[x]].insert(p(stc[v].begin()->first,z));
it=stf[fa[x]].begin();if(it->second==c[fa[x]])++it;
change(fa[x],it->first);
}
it=stf[x].begin();if(it->second==(c[x]=z))++it;
change(x,it->first);
}
int main()
{
freopen("grass.in","r",stdin);
freopen("grass.out","w",stdout);
int n,m,k,q,i;
n=read();m=read();k=read();q=read();
for(i=;i<=m;++i)E[i].x=read(),E[i].y=read(),E[i].w=read();
sort(E+,E+m+,cmp);
for(i=;i<=m;++i)if(gf(E[i].x)!=gf(E[i].y))f[gf(E[i].x)]=gf(E[i].y),ins(E[i].x,E[i].y,E[i].w);
for(i=;i<=n;++i)c[i]=read();
memset(t,,sizeof(t));dfs();
while(q--)i=read(),renew(i,read()),printf("%d\n",t[]);
fclose(stdin);fclose(stdout);return ;
}
USACO 2017 US Open的更多相关文章
- [USACO 2017 Dec Gold] Tutorial
Link: USACO 2017 Dec Gold 传送门 A: 为了保证复杂度明显是从终结点往回退 结果一开始全在想优化建边$dfs$……其实可以不用建边直接$multiset$找可行边跑$bfs$ ...
- NC24083 [USACO 2017 Dec P]Greedy Gift Takers
NC24083 [USACO 2017 Dec P]Greedy Gift Takers 题目 题目描述 Farmer John's nemesis, Farmer Nhoj, has N cows ...
- USACO 2017 February Platinum
第二次参加USACO 本来打算2016-2017全勤的 January的好像忘记打了 听群里有人讨论才想起来铂金组三题很有意思,都是两个排列的交叉对问题 我最后得分889/1000(真的菜) T1.W ...
- [USACO] 2017 DEC Bronze&Silver
link:http://www.usaco.org/index.php?page=dec17results Problem A(Bronze) 这是一道非常简单的判断重叠面积的题目,但第一次提交仍会出 ...
- USACO 2017 February Gold
那天打cf前无聊练手 T1.Why Did the Cow Cross the Road 题目大意:N*N的矩阵,从左上角走到右下角,走一步消耗T,每走3步消耗当前所在位置上的权值,求最小消耗 思路: ...
- USACO 2017 January Platinum
因为之前忘做了,赶紧补上. T1.Promotion Counting 题目大意:给定一个以1为根的N个节点的树(N<=100,000),每个节点有一个权值,对于每个节点求出权值比它大的子孙的个 ...
- USACO 2017 FEB Platinum mincross 可持久化线段树
题意 上下有两个位置分别对应的序列A.B,长度为n,两序列为n的一个排列.当Ai == Bj时,上下会连一条边.你可以选择序列A或者序列B进行旋转任意K步,如 3 4 1 5 2 旋转两步为 5 2 ...
- USACO 2017 FEB Gold visitfj 最短路
题意 有一幅n*n的方格图,n <= 100,每个点上有一个值.从(1,1)出发,走到(n,n),只能走四联通.每走一步花费t,每走三步需要花费走完三步后到达格子的值.求最小花费的值. 拆点,d ...
- USACO 2017 FEB Platinum nocross DP
题目大意 上下有两个长度为n.位置对应的序列A.B,其中数的范围均为1~n.若abs(A[i]-B[j]) <= 4,则A[i]与B[j]间可以连一条边.现要求在边与边不相交的情况下的最大的连边 ...
随机推荐
- verilog学习笔记(0)
assign赋值语句根本不允许出现在always语句块中 位于begin/end块内的多条阻塞赋值语句是串行执行的; 但是多条非阻塞赋值语句却是并行执行的,这些非阻塞赋值语句都会在其中任何一条语句执行 ...
- aix 6.1系统怎么安装?这里有详细图文教程
今年六月,我们公司出现了一次非常严重的数据丢失的事故.生产服务器崩溃导致所有的业务都陷于停滞,而且由于涉及到公司机密又无法贸然到数据恢复公司进行恢复,可是自己又无法解决.权衡利弊还是决定找一家有保密资 ...
- Css之导航栏下拉菜单
Css: /*下拉菜单学习-2017.12.17 20:17 added by ldb*/ ul{ list-style-type:none; margin:; padding:; overflow: ...
- $.ajax 中的contentType
$.ajax 中的contentType 在 cnodejs.org 论坛中有一个问题,让我也很奇怪,说是 $.ajax 设置数据类型 applicaiton/json之后,服务器端(express) ...
- jquery 实时监听输入框值变化方法
$('.offers-number').bind('input propertychange', function (a, b) { var value = $(this).val() if (!va ...
- “认证发布”和“获取展示”,如何在 SharePoint 中正确使用 RSS Feed。
在我们进行的日常工作中,是由一部分信息需要 Share 给其他人或者组织的.SharePoint 虽然支持在某个 Site Collection 中互通信息,但是跨 Site Collection 的 ...
- Linux CentOS7.0 (01)在Vmvare Workstation上 安装配置
一.新建虚拟机 1.创建新的虚拟机 -> 默认典型 ->选择安装介质 2.指定虚拟机名称.安装目录.磁盘容量大小 点击 "完成",创建虚拟机! 随后虚拟机将自动启动安装 ...
- 新概念英语(1-29)Come in, Amy.
How must Amy clean the floor? A:Come in, Amy. Shut the door, please. This bedroom's very untidy. B:W ...
- 【52ABP实战教程】00-- ASP.NET CORE系列介绍
为什么是.net core? 记得在半年前.NET CORE刚刚出了1.0,当时有朋友推荐我使用的时候,个人觉得还不成熟. 现在.NET Core已经到了2.0,.NET Standard 2.0 添 ...
- [NOIP2009][LuoguP1073] 最优贸易 - Tarjan,拓扑+DP
Description&Data 题面:https://www.luogu.org/problemnew/show/P1073 Solution Tarjan对联通块缩点,在DAG上按照拓扑序 ...