只会做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的更多相关文章

  1. [USACO 2017 Dec Gold] Tutorial

    Link: USACO 2017 Dec Gold 传送门 A: 为了保证复杂度明显是从终结点往回退 结果一开始全在想优化建边$dfs$……其实可以不用建边直接$multiset$找可行边跑$bfs$ ...

  2. 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 ...

  3. USACO 2017 February Platinum

    第二次参加USACO 本来打算2016-2017全勤的 January的好像忘记打了 听群里有人讨论才想起来铂金组三题很有意思,都是两个排列的交叉对问题 我最后得分889/1000(真的菜) T1.W ...

  4. [USACO] 2017 DEC Bronze&Silver

    link:http://www.usaco.org/index.php?page=dec17results Problem A(Bronze) 这是一道非常简单的判断重叠面积的题目,但第一次提交仍会出 ...

  5. USACO 2017 February Gold

    那天打cf前无聊练手 T1.Why Did the Cow Cross the Road 题目大意:N*N的矩阵,从左上角走到右下角,走一步消耗T,每走3步消耗当前所在位置上的权值,求最小消耗 思路: ...

  6. USACO 2017 January Platinum

    因为之前忘做了,赶紧补上. T1.Promotion Counting 题目大意:给定一个以1为根的N个节点的树(N<=100,000),每个节点有一个权值,对于每个节点求出权值比它大的子孙的个 ...

  7. USACO 2017 FEB Platinum mincross 可持久化线段树

    题意 上下有两个位置分别对应的序列A.B,长度为n,两序列为n的一个排列.当Ai == Bj时,上下会连一条边.你可以选择序列A或者序列B进行旋转任意K步,如 3 4 1 5 2 旋转两步为 5 2 ...

  8. USACO 2017 FEB Gold visitfj 最短路

    题意 有一幅n*n的方格图,n <= 100,每个点上有一个值.从(1,1)出发,走到(n,n),只能走四联通.每走一步花费t,每走三步需要花费走完三步后到达格子的值.求最小花费的值. 拆点,d ...

  9. USACO 2017 FEB Platinum nocross DP

    题目大意 上下有两个长度为n.位置对应的序列A.B,其中数的范围均为1~n.若abs(A[i]-B[j]) <= 4,则A[i]与B[j]间可以连一条边.现要求在边与边不相交的情况下的最大的连边 ...

随机推荐

  1. 17-TypeScript代理模式

    在有些情况下,我们需要把客户端真正调用的类和方法隐藏起来,而通过暴露代理类给客户端.客户端调用代理类的方式就可以访问到真实类提供的功能. abstract class Called{ protecte ...

  2. JAVA_SE基础——47.接口

    如果一个抽象类中的所有方法都是抽象的,则可以将这个类用另一种方法来定义,即接口~ 在定义接口时,需要用interface关键字来声明,具体实例如code1 接口的定义格式:interface 接口名{ ...

  3. Column Addition~DP(脑子抽了,当时没有想到)

    Description A multi-digit column addition is a formula on adding two integers written like this:

  4. Struts2 配置文件小结

    每次写的博文都被管理员都被移出首页,好气!还希望有哪位大神可以指点迷津-- struts2 配置文件的 result 节点 result 节点是 action 节点的子节点,他代表着 action 方 ...

  5. vue组件详解(二)——使用props传递数据

    在 Vue 中,父子组件的关系可以总结为 props向下传递,事件向上传递.父组件通过 props 给子组件下发数据,子组件通过事件给父组件发送消息.看看它们是怎么工作的.  一.基本用法 组件不仅仅 ...

  6. 新概念英语(1-115)Knock! Knock!

    Lesson 115 Knock, knock! 敲敲门! Listen to the tape then answer this question. What does Jim have to dr ...

  7. hadoop2.6.0实践:000 虚拟机配置

  8. hadoop2.6.0实践:004 启动伪分布式hadoop的进程

    [hadoop@LexiaofeiMaster hadoop-2.6.0]$ start-dfs.shStarting namenodes on [localhost]localhost: start ...

  9. 新概念英语(1-39)Don't drop it!

    新概念英语(1-39)Don't drop it! Where does Sam put the vase in the end ? A:What are you going to do with t ...

  10. 集智robot微信公众号开发笔记

    开发流程 公众号基本配置(首先得有公众平台账号) 在开发菜单的基本配置中填写好基本配置项 首先配置服务器地址.Token.和消息加密密钥(地址为开发者为微信验证留的接口.token可以随便填写,只要在 ...