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]间可以连一条边.现要求在边与边不相交的情况下的最大的连边 ...
随机推荐
- Alpha冲刺Day2
Alpha冲刺Day2 一:站立式会议 今日安排: 首先完善前一天的剩余安排工作量,其次我们把项目大体分为四个模块:数据管理员.企业人员.第三方机构.政府人员.数据管理员这一模块,数据管理员又可细分为 ...
- C语言--第四周作业
一.题目7-1 计算分段函数[1] 1.代码 #include <stdio.h> int main () { float x,result; scanf("%f",& ...
- JAVA对象克隆
1> 为了获取对象的一份拷贝,我们可以利用Object类的clone()方法. 2> 在派生类中覆盖基类的clone(),并声明为public.3> 在派生类的clone()方法中, ...
- 201421123042 《Java程序设计》第4周学习总结
1. 本周学习总结 1.1 写出你认为本周学习中比较重要的知识点关键词 继承中的关键词:Soper,object,override,project, 1.2 尝试使用思维导图将这些关键词组织起来.注: ...
- vue项目结构
前言 我在 搭建vue项目环境 简单说明了项目初始化完成后的目录结构. 但在实际项目中,src目录下的结构需要跟随项目做一些小小的调整. 目录结构 ├── src 项目源码目录 │ ├── api 所 ...
- CSS <input type="file">样式设置
这是最终想要的效果~~~ 实现很简单,div设置背景图片,<input type="file"/>绝对定位上去再设置opacity:0(透明度为0 ) 直接上代码,希望 ...
- navicate连接不上阿里云mysql
一 用xshell连接进入服务器: 二 使用命令连接mysql mysql -uroot -p 三 更新权限 GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDE ...
- Web Api 使用模型验证
public class Person { public int Id { get; set; } [Required(ErrorMessage = "姓名不能为空啊啊啊!")] ...
- Oracle10g物理DG详细配置方法及步骤
--测试环境: OS:Redhat linux(64) Primary: IP:192.168.94.198 SID:dgdb1 Hostname:dg1 DB_U ...
- Spring Security入门(2-2)Spring Security 的运行原理 2