集合相等问题
Time Limit: 1000MS
Memory Limit: 65536KB
Problem Description
给定2 个集合S和T,试设计一个判定S和T是否相等的蒙特卡罗算法。
设计一个拉斯维加斯算法,对于给定的集合S和T,判定其是否相等。
设计一个拉斯维加斯算法,对于给定的集合S和T,判定其是否相等。
Input
输入数据的第一行有1 个正整数n(n≤10000),表示集合的大小。接下来的2行,每行有n个正整数,分别表示集合S和T中的元素。
Output
将计算结论输出。集合S和T相等则输出YES,否则输出NO。
Example Input
3 2 3 7 7 2 3
Example Output
YES
import java.util.*; import java.util.zip.ZipEntry; import javax.swing.plaf.basic.BasicBorders.SplitPaneBorder; public class Main { public static void main(String[] args) { Scanner input=new Scanner(System.in); int n=input.nextInt(); int a[]=new int[10001]; int b[]=new int[10001]; for(int i=0;i<n;i++){ a[i]=input.nextInt(); } for(int i=0;i<n;i++){ b[i]=input.nextInt(); } for(int i=0;i<n-1;i++){ for(int j=0;j<n-i-1;j++) { if(a[j]>a[j+1]){ int t=a[j]; a[j]=a[j+1]; a[j+1]=t; } if(b[j]>b[j+1]){ int t=b[j]; b[j]=b[j+1]; b[j+1]=t; } } } int flag=1; for(int i=0;i<n;i++){ if(a[i]!=b[i]){ System.out.println("NO"); flag=0; break; } } if(flag==1){ System.out.println("YES"); } } }