NYOJ-8-一种排序(comparator排序)
2013-08-07 17:17
309 查看
题目8
题目信息
运行结果
本题排行
讨论区
一种排序
时间限制:3000 ms | 内存限制:65535 KB
难度:3
描述
现在有很多长方形,每一个长方形都有一个编号,这个编号可以重复;还知道这个长方形的宽和长,编号、长、宽都是整数;现在要求按照一下方式排序(默认排序规则都是从小到大);
1.按照编号从小到大排序
2.对于编号相等的长方形,按照长方形的长排序;
3.如果编号和长都相同,按照长方形的宽排序;
4.如果编号、长、宽都相同,就只保留一个长方形用于排序,删除多余的长方形;最后排好序按照指定格式显示所有的长方形;
输入
第一行有一个整数 0<n<10000,表示接下来有n组测试数据;
每一组第一行有一个整数 0<m<1000,表示有m个长方形;
接下来的m行,每一行有三个数 ,第一个数表示长方形的编号,
第二个和第三个数值大的表示长,数值小的表示宽,相等
说明这是一个正方形(数据约定长宽与编号都小于10000);
输出
顺序输出每组数据的所有符合条件的长方形的 编号 长 宽
样例输入
样例输出
来源
经典题目
上传者
iphxer
其他做法(Java):comparator排序
题目信息
运行结果
本题排行
讨论区
一种排序
时间限制:3000 ms | 内存限制:65535 KB
难度:3
描述
现在有很多长方形,每一个长方形都有一个编号,这个编号可以重复;还知道这个长方形的宽和长,编号、长、宽都是整数;现在要求按照一下方式排序(默认排序规则都是从小到大);
1.按照编号从小到大排序
2.对于编号相等的长方形,按照长方形的长排序;
3.如果编号和长都相同,按照长方形的宽排序;
4.如果编号、长、宽都相同,就只保留一个长方形用于排序,删除多余的长方形;最后排好序按照指定格式显示所有的长方形;
输入
第一行有一个整数 0<n<10000,表示接下来有n组测试数据;
每一组第一行有一个整数 0<m<1000,表示有m个长方形;
接下来的m行,每一行有三个数 ,第一个数表示长方形的编号,
第二个和第三个数值大的表示长,数值小的表示宽,相等
说明这是一个正方形(数据约定长宽与编号都小于10000);
输出
顺序输出每组数据的所有符合条件的长方形的 编号 长 宽
样例输入
1 8 1 1 1 1 1 1 1 1 2 1 2 1 1 2 2 2 1 1 2 1 2 2 2 1
样例输出
1 1 1 1 2 1 1 2 2 2 1 1 2 2 1
来源
经典题目
上传者
iphxer
mport java.util.Arrays; import java.util.Comparator; import java.util.Scanner;//一种排序 Accepted 112 2711 java 08-07 16:57:50 public class NYOJ_3_一种排序{ public static void main(String[] args) { Scanner scan=new Scanner (System.in); int N=scan.nextInt(); int a,b,c; while(N--!=0){ int M=scan.nextInt(); Rectangular [] arr=new Rectangular[M];//相当于C语言的结构体! for(int i=0;i<M;i++){ Rectangular rt=new Rectangular(); rt.id=scan.nextInt(); a=scan.nextInt(); b=scan.nextInt(); rt.length=Math.max(a, b);//直接转换为length>=width! rt.width=a+b-rt.length; arr[i]=rt; //每一个成员,加入到arr[]里 } Arrays.sort(arr, new RectComparator());//对加入的成员的每个的属性也进行排序 a=arr[0].id; b=arr[0].length; c=arr[0].width; System.out.println(arr[0].id+" "+arr[0].length+" "+arr[0].width); for(int i=1; i< arr.length; i++){ if(a==arr[i].id&&b==arr[i].length&&c==arr[i].width){ continue; }else{ System.out.println(arr[i].id+" "+arr[i].length+" "+arr[i].width); a=arr[i].id; b=arr[i].length; c=arr[i].width; } } } } } class RectComparator implements Comparator<Rectangular>{ public int compare(Rectangular r1, Rectangular r2) { if(r1.id!=r2.id){ return r1.id > r2.id ? 1 : -1 ; }else if(r1.id==r2.id&&r1.length!=r2.length){ return r1.length > r2.length ? 1 : -1; }else return r1.width > r2.width ? 1 : -1 ; } } class Rectangular{ int id,length,width; }
其他做法(Java):comparator排序
import java.util.Comparator; import java.util.Iterator; import java.util.Scanner; import java.util.TreeSet; public class NYOJ_3_一种排序{//张燚 一种排序 Accepted 151 2776 java 08-06 21:56:07 nyoj @SuppressWarnings("unchecked") public static void main(String[] args) { Scanner input=new Scanner(System.in); int N=input.nextInt(); while(N-->0){ int n=input.nextInt(); TreeSet ts=new TreeSet(new SORT()); for(int i=0;i<n;i++){ int a=input.nextInt(); int b=input.nextInt(); int c=input.nextInt(); if(b<c){ int d=b; b=c; c=d; } F f=new F(a,b,c); ts.add(f); } Iterator it=ts.iterator(); F f[]=new F[n+1]; int e=-1; while(it.hasNext()){ F r=(F) it.next(); if(e==-1){ f[++e]=r; } else if(!(r.bianhao==f[e].bianhao&&r.c==f[e].c&&r.k==f[e].k)){ f[++e]=r; } } for(int i=0;i<=e;i++){ System.out.println(f[i].bianhao+" "+f[i].c+" "+f[i].k); } } } } class SORT implements Comparator<F>{ @Override public int compare(F o1, F o2) { if(o1.bianhao>o2.bianhao) return 1; else if(o1.bianhao==o2.bianhao&&o1.c>o2.c) return 1; else if(o1.bianhao==o2.bianhao&&o1.c==o2.c&&o1.k>o2.k) return 1; else return -1; } } class F{ int bianhao,c,k; F(int bianhao,int c,int k){ this.bianhao=bianhao; this.c=c; this.k=k; } F(){} }
相关文章推荐