Splatter Painting题目代码
来源:互联网 发布:ansys软件一般多大 编辑:程序博客网 时间:2024/05/20 13:09
题目源:http://agc012.contest.atcoder.jp/tasks/agc012_b 存边的方法我就不说了
这题的做法说白了就是强暴力+优化
染色从后往前染(不解释)
对于每个点,标记该点已染色的最大范围,搜到该点时,若还需染色的范围比标记小就不用染下去了
下面贴代码,注意数组要开两倍
type arr=array[0..200001]of longint;var n,q,m,i,j,a,b:longint; v,d,c,max,cl,head,next,start,endd:arr; bb,bc:array[0..200001]of boolean;procedure dfs(k,dis,col:longint);var i:longint;begin bb[k]:=true; if(max[k]>=dis)and(bc[k])then begin bb[k]:=false; exit; end; max[k]:=dis; if not bc[k]then begin cl[k]:=col; bc[k]:=true; end; if dis>0 then for i:=start[k] to endd[k] do if not bb[next[i]]then dfs(next[i],dis-1,col); bb[k]:=false;end;procedure sort(l,r:longint);var i,j,x,y:longint;begin i:=l;j:=r;x:=head[(l+r) div 2]; repeat while head[i]<x do inc(i); while x<head[j] do dec(j); if not(i>j) then begin y:=head[i];head[i]:=head[j];head[j]:=y; y:=next[i];next[i]:=next[j];next[j]:=y; inc(i);j:=j-1; end; until i>j; if l<j then sort(l,j); if i<r then sort(i,r);end;begin readln(n,m); fillchar(cl,sizeof(cl),0); fillchar(max,sizeof(max),0); fillchar(bb,sizeof(bb),false); fillchar(bc,sizeof(bc),false); for i:=1 to m do begin readln(a,b); head[i]:=a;head[i+m]:=b; next[i]:=b;next[i+m]:=a; end; m:=m*2;sort(1,m);start[head[1]]:=1; for i:=2 to m do if head[i]<>head[i-1]then begin endd[head[i-1]]:=i-1; start[head[i]]:=i; end; endd[head[m]]:=m; readln(q); for i:=q downto 1 do readln(v[i],d[i],c[i]); for i:=1 to q do dfs(v[i],d[i],c[i]); for i:=1 to n do writeln(cl[i]);end.
阅读全文
0 0
- Splatter Painting题目代码
- Splatter Painting
- Atcoder #2362 Splatter Painting(dfs+优化)
- Atcoder AGC B Splatter Painting 记忆化+逆向模拟
- POJ 题目1691 Painting A Board(DFS)
- Codeforces 448C:Painting Fence 刷栅栏 超级好玩的一道题目
- JAVA开会题目代码
- C++题目 代码
- PAT简单题目代码
- 面试手写代码题目
- lua 代码题目
- oil painting
- Painting Artist
- Painting Eggs
- Cube painting
- Cube painting
- Cube painting
- Painting Storages
- EXCEL一列索引项筛选数据
- idea安装maven
- vs2015 qt5.8新添加文件时出现“无法找到源文件ui.xxx.h”
- Vue开发配置cnpm
- 把数组排成最小的数
- Splatter Painting题目代码
- vue和svg(一),用svg画出带坐标系的进度条
- 如何选择合适的开源消息中间件
- Java内部类(3):非静态内部类为什么不能有静态成员变量和静态方法。
- WinForm窗体中ComboBox控件自定义高度和选项文本居中、选项高亮
- Linux链接库三(C跟C++之间动态库的相互调用)
- 设计模式-策略模式
- JAVA8-Predicate函数使用
- ehcache2.10+spring4 整合要注意的问题