内容:染色划分,带权并查集,扩展并查集
Arpa’s overnight party and Mehrdad’s silent entering
题目链接
题目大意
data:image/s3,"s3://crabby-images/406bf/406bfbb4765ecda1cd42760c5921c211bba36213" alt="2n"
data:image/s3,"s3://crabby-images/68b0a/68b0a20034b4801785cef3150a6379cd5fea0e57" alt="n"
解题思路
将每对进行的连边看作一类边将为满足相邻3个点必须有两个点不同染色的边,看作二类边满足构造方案,即将data:image/s3,"s3://crabby-images/4f3d7/4f3d717b629abb3c565bbcc33789ed4384a5b5be" alt="2n"
data:image/s3,"s3://crabby-images/fb13e/fb13ecd1aea47171d574a7172191fe43c463f038" alt="2_i\leftrightarrow 2_i+1"
data:image/s3,"s3://crabby-images/f3024/f30242b5b2816adb740b90db1b903d7fe377e518" alt=""
import java.io.*;import java.math.BigInteger;import java.util.Arrays;import java.util.BitSet;import java.util.HashMap;import java.util.HashSet;import java.util.Iterator;import java.util.LinkedList;import java.util.PriorityQueue;import java.util.Queue;import java.util.StringTokenizer;import java.util.Vector;public class Main{static int find(int x,int[] fa,int[] relation) {if(x==fa[x])return x;else {int f=fa[x];fa[x]=find(fa[x], fa, relation);relation[x]=(relation[x]+relation[f])%2;return fa[x];}}public static void main(String[] args) throws IOException{AReader input=new AReader(); PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out)); int n=input.nextInt(); int[] fa=new int[2*n+1]; int[] relation=new int[2*n+1]; for(int i=1;i<=2*n;++i)fa[i]=i; int[] a=new int[n+1]; int[] b=new int[n+1]; for(int i=1;i<=n;++i) { int x=input.nextInt(); int y=input.nextInt(); a[i]=x;b[i]=y; int fx=find(x, fa, relation); int fy=find(y, fa, relation); if(fx==fy)continue; fa[fx]=fy; relation[fx]=(relation[y]+1-relation[x]+2)%2; } for(int i=1;i<=n;++i) {//一圈 int x=2*i; int y=i==n?1:2*i+1; int fx=find(x, fa, relation); int fy=find(y, fa, relation); if(fx==fy)continue; fa[fx]=fy; relation[fx]=(relation[y]+1-relation[x]+2)%2; } for(int i=1;i<=n;++i) { find(a[i], fa, relation); find(b[i], fa, relation); int x=relation[a[i]]+1; int y=relation[b[i]]+1; out.println(x+" "+y); } out.flush(); out.close();}staticclass AReader{ BufferedReader bf; StringTokenizer st; BufferedWriter bw; public AReader(){ bf=new BufferedReader(new InputStreamReader(System.in)); st=new StringTokenizer(""); bw=new BufferedWriter(new OutputStreamWriter(System.out)); } public String nextLine() throws IOException{ return bf.readLine(); } public String next() throws IOException{ while(!st.hasMoreTokens()){ st=new StringTokenizer(bf.readLine()); } return st.nextToken(); } public char nextChar() throws IOException{ //确定下一个token只有一个字符的时候再用 return next().charAt(0); } public int nextInt() throws IOException{ return Integer.parseInt(next()); } public long nextLong() throws IOException{ return Long.parseLong(next()); } public double nextDouble() throws IOException{ return Double.parseDouble(next()); } public float nextFloat() throws IOException{ return Float.parseFloat(next()); } public byte nextByte() throws IOException{ return Byte.parseByte(next()); } public short nextShort() throws IOException{ return Short.parseShort(next()); } public BigInteger nextBigInteger() throws IOException{ return new BigInteger(next()); } public void println() throws IOException { bw.newLine(); } public void println(int[] arr) throws IOException{ for (int value : arr) { bw.write(value + " "); } println(); } public void println(int l, int r, int[] arr) throws IOException{ for (int i = l; i <= r; i ++) { bw.write(arr[i] + " "); } println(); } public void println(int a) throws IOException{ bw.write(String.valueOf(a)); bw.newLine(); } public void print(int a) throws IOException{ bw.write(String.valueOf(a)); } public void println(String a) throws IOException{ bw.write(a); bw.newLine(); } public void print(String a) throws IOException{ bw.write(a); } public void println(long a) throws IOException{ bw.write(String.valueOf(a)); bw.newLine(); } public void print(long a) throws IOException{ bw.write(String.valueOf(a)); } public void println(double a) throws IOException{ bw.write(String.valueOf(a)); bw.newLine(); } public void print(double a) throws IOException{ bw.write(String.valueOf(a)); } public void print(char a) throws IOException{ bw.write(String.valueOf(a)); } public void println(char a) throws IOException{ bw.write(String.valueOf(a)); bw.newLine(); }}}
食物链
题目链接
题目大意
data:image/s3,"s3://crabby-images/b849d/b849d52778af2b48f4799234309fbe138a207b17" alt="n"
data:image/s3,"s3://crabby-images/2bfc6/2bfc6bb2fea2157157b8e6edc9c191d26fd65004" alt="k"
data:image/s3,"s3://crabby-images/63450/634504319c0378ca0e6c99fb91ff641c31caea52" alt="A/B/C"
data:image/s3,"s3://crabby-images/781f4/781f448fa1b61703ce2f8824a4ab9f7463d7c339" alt="A"
data:image/s3,"s3://crabby-images/83d64/83d6416229d3da24b4d68c7a904a7782a1175000" alt="B"
data:image/s3,"s3://crabby-images/91a96/91a960a26e87a0df4d5c10dc37d5204348887043" alt="B"
data:image/s3,"s3://crabby-images/56293/562932f7605e8877804cc7791a81d016caaeaac7" alt="C"
data:image/s3,"s3://crabby-images/db8f3/db8f3a59a308344e321a18fa794ad69e14ccae76" alt="C"
data:image/s3,"s3://crabby-images/3cec4/3cec4ba04aeb72610f2ad1680fe59cd95a27ea81" alt="A"
data:image/s3,"s3://crabby-images/3a70b/3a70bc9798e770a28fed28f05279499f1fa16e0d" alt="k"
data:image/s3,"s3://crabby-images/62a74/62a74d725e574bc9aaf52fcfeacd1341528a6278" alt="1,x,y"
data:image/s3,"s3://crabby-images/37ce8/37ce88523c533831f997f575059081e38c2be063" alt="x,y"
data:image/s3,"s3://crabby-images/4b9cd/4b9cdedd963c0d541390bf1676045776c8d26161" alt="2,x,y"
data:image/s3,"s3://crabby-images/39d7e/39d7e89d34dfcd1e6932a47d3c3956f4d8737196" alt="x"
data:image/s3,"s3://crabby-images/17bd7/17bd75b26070a79656401eff9f0a0c8019ccef7b" alt="y"
data:image/s3,"s3://crabby-images/8bba9/8bba93cd57550036df5f69254994ff5231225f67" alt="k"
data:image/s3,"s3://crabby-images/b012e/b012e3b2a730daf43365e5c19ed66de84bc9c975" alt="x>n,y>n,(2,x,y)x=y"
解题思路
对data:image/s3,"s3://crabby-images/c08ac/c08ac1888e49d604b6a743e1c616dfa6f17fa495" alt="n"
data:image/s3,"s3://crabby-images/277cb/277cb76504b45d23baf9edb88dc9c24a8d75feed" alt="3"
扩展并查集
import java.io.*;import java.math.BigInteger;import java.util.Arrays;import java.util.BitSet;import java.util.HashMap;import java.util.HashSet;import java.util.Iterator;import java.util.LinkedList;import java.util.PriorityQueue;import java.util.Queue;import java.util.StringTokenizer;import java.util.Vector; public class Main{static int find(int x,int[] fa) {if(x==fa[x])return x;else return fa[x]=find(fa[x], fa);}public static void main(String[] args) throws IOException{AReader input=new AReader(); PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out)); int n=input.nextInt(); int k=input.nextInt(); int[] fa=new int[3*n+1]; for(int i=1;i<=3*n;++i)fa[i]=i; int ans=0; for(int i=1;i<=k;++i) { int op=input.nextInt(); int x=input.nextInt(); int y=input.nextInt(); if(x>n||y>n) { ans++; continue; } if(op==1) { if(find(x, fa)==find(y+n, fa)||find(y, fa)==find(x+n, fa)) { //x吃y或y吃x //x吃y=>xA->yB,xB->yC,xC->yA //y吃x=>yA->xB,yB->xC->yC->xA ans++; continue; } fa[find(x, fa)]=find(y, fa); fa[find(x+n, fa)]=find(y+n, fa); fa[find(x+2*n, fa)]=find(y+2*n, fa); }else { if(x==y) { ans++; continue; } if(find(x, fa)==find(y, fa)||find(y, fa)==find(x+n, fa)) { //x和y是同类,y吃x ans++; continue; } fa[find(x, fa)]=find(y+n, fa); fa[find(x+n, fa)]=find(y+2*n, fa); fa[find(x+2*n, fa)]=find(y, fa); } } out.print(ans); out.flush(); out.close();}staticclass AReader{ BufferedReader bf; StringTokenizer st; BufferedWriter bw; public AReader(){ bf=new BufferedReader(new InputStreamReader(System.in)); st=new StringTokenizer(""); bw=new BufferedWriter(new OutputStreamWriter(System.out)); } public String nextLine() throws IOException{ return bf.readLine(); } public String next() throws IOException{ while(!st.hasMoreTokens()){ st=new StringTokenizer(bf.readLine()); } return st.nextToken(); } public char nextChar() throws IOException{ //确定下一个token只有一个字符的时候再用 return next().charAt(0); } public int nextInt() throws IOException{ return Integer.parseInt(next()); } public long nextLong() throws IOException{ return Long.parseLong(next()); } public double nextDouble() throws IOException{ return Double.parseDouble(next()); } public float nextFloat() throws IOException{ return Float.parseFloat(next()); } public byte nextByte() throws IOException{ return Byte.parseByte(next()); } public short nextShort() throws IOException{ return Short.parseShort(next()); } public BigInteger nextBigInteger() throws IOException{ return new BigInteger(next()); } public void println() throws IOException { bw.newLine(); } public void println(int[] arr) throws IOException{ for (int value : arr) { bw.write(value + " "); } println(); } public void println(int l, int r, int[] arr) throws IOException{ for (int i = l; i <= r; i ++) { bw.write(arr[i] + " "); } println(); } public void println(int a) throws IOException{ bw.write(String.valueOf(a)); bw.newLine(); } public void print(int a) throws IOException{ bw.write(String.valueOf(a)); } public void println(String a) throws IOException{ bw.write(a); bw.newLine(); } public void print(String a) throws IOException{ bw.write(a); } public void println(long a) throws IOException{ bw.write(String.valueOf(a)); bw.newLine(); } public void print(long a) throws IOException{ bw.write(String.valueOf(a)); } public void println(double a) throws IOException{ bw.write(String.valueOf(a)); bw.newLine(); } public void print(double a) throws IOException{ bw.write(String.valueOf(a)); } public void print(char a) throws IOException{ bw.write(String.valueOf(a)); } public void println(char a) throws IOException{ bw.write(String.valueOf(a)); bw.newLine(); }}}
带权并查集
import java.io.*;import java.math.BigInteger;import java.util.Arrays;import java.util.BitSet;import java.util.HashMap;import java.util.HashSet;import java.util.Iterator;import java.util.LinkedList;import java.util.PriorityQueue;import java.util.Queue;import java.util.StringTokenizer;import java.util.Vector; public class Main{static int find(int x,int[] fa,int[] relation) {if(x==fa[x])return x;else {int f=fa[x];fa[x]=find(fa[x], fa, relation);relation[x]=(relation[x]+relation[f])%3;return fa[x];}}public static void main(String[] args) throws IOException{AReader input=new AReader(); PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out)); int n=input.nextInt(); int k=input.nextInt(); int ans=0; int[] fa=new int[n+1]; int[] relation=new int[n+1]; for(int i=1;i<=n;++i) fa[i]=i; for(int i=1;i<=k;++i) { int op=input.nextInt(); int x=input.nextInt(); int y=input.nextInt(); if(x>n||y>n) { ans++; continue; } if(op==1) { int fx=find(x, fa, relation); int fy=find(y, fa, relation); if(fx==fy) { if(relation[x]!=relation[y]) { ans++; continue; } }else { fa[fx]=fy; relation[fx]=(relation[y]+0-relation[x]+3)%3; } }else { if(x==y) { ans++; continue; } int fx=find(x, fa, relation); int fy=find(y, fa, relation); if(fx==fy) {//0吃1,1吃2,2吃0 if(relation[x]==0&&relation[y]==1|| relation[x]==1&&relation[y]==2|| relation[x]==2&&relation[y]==0)continue; ans++; continue; }else { fa[fx]=fy; relation[fx]=(relation[y]+2-relation[x]+3)%3; } } } out.println(ans); out.flush(); out.close();}staticclass AReader{ BufferedReader bf; StringTokenizer st; BufferedWriter bw; public AReader(){ bf=new BufferedReader(new InputStreamReader(System.in)); st=new StringTokenizer(""); bw=new BufferedWriter(new OutputStreamWriter(System.out)); } public String nextLine() throws IOException{ return bf.readLine(); } public String next() throws IOException{ while(!st.hasMoreTokens()){ st=new StringTokenizer(bf.readLine()); } return st.nextToken(); } public char nextChar() throws IOException{ //确定下一个token只有一个字符的时候再用 return next().charAt(0); } public int nextInt() throws IOException{ return Integer.parseInt(next()); } public long nextLong() throws IOException{ return Long.parseLong(next()); } public double nextDouble() throws IOException{ return Double.parseDouble(next()); } public float nextFloat() throws IOException{ return Float.parseFloat(next()); } public byte nextByte() throws IOException{ return Byte.parseByte(next()); } public short nextShort() throws IOException{ return Short.parseShort(next()); } public BigInteger nextBigInteger() throws IOException{ return new BigInteger(next()); } public void println() throws IOException { bw.newLine(); } public void println(int[] arr) throws IOException{ for (int value : arr) { bw.write(value + " "); } println(); } public void println(int l, int r, int[] arr) throws IOException{ for (int i = l; i <= r; i ++) { bw.write(arr[i] + " "); } println(); } public void println(int a) throws IOException{ bw.write(String.valueOf(a)); bw.newLine(); } public void print(int a) throws IOException{ bw.write(String.valueOf(a)); } public void println(String a) throws IOException{ bw.write(a); bw.newLine(); } public void print(String a) throws IOException{ bw.write(a); } public void println(long a) throws IOException{ bw.write(String.valueOf(a)); bw.newLine(); } public void print(long a) throws IOException{ bw.write(String.valueOf(a)); } public void println(double a) throws IOException{ bw.write(String.valueOf(a)); bw.newLine(); } public void print(double a) throws IOException{ bw.write(String.valueOf(a)); } public void print(char a) throws IOException{ bw.write(String.valueOf(a)); } public void println(char a) throws IOException{ bw.write(String.valueOf(a)); bw.newLine(); }}}