一种排序

时间限制: 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
来源
经典题目
import java.util.Comparator;
import java.util.Iterator;
import java.util.Scanner;
import java.util.TreeSet; public class Main{//张燚 一种排序 Accepted 151 2776 java 08-06 21:56:07 nyoj
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(){}
}
import java.util.Arrays;
import java.util.Comparator;
import java.util.Scanner; public class Main{//一种排序 Accepted 215MS 2771 java 2013-08-07 09:41:06
public static void main(String[] args) {
Scanner input=new Scanner(System.in);
int N=input.nextInt();
while(N-->0){
int n=input.nextInt();
F f[]=new F[n];
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[i]=new F(a,b,c);
}
Arrays.sort(f,new SORT());
for(int i=0;i<n;i++){
if(i==0)
System.out.println(f[i].bianhao+" "+f[i].c+" "+f[i].k);
else if(!(f[i].bianhao==f[i-1].bianhao&&f[i].c==f[i-1].c&&f[i].k==f[i-1].k)){
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(){}
}
 import java.util.Arrays;
import java.util.Comparator;
import java.util.Scanner; public class Main{//一种排序 Accepted 313MS 2771 java 2013-08-07 09:57:57
public static void main(String[] args) {
Scanner input=new Scanner(System.in);
int N=input.nextInt();
while(N-->0){
int n=input.nextInt();
F f[]=new F[n];
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[i]=new F(a,b,c);
}
Arrays.sort(f,new 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;
}
});
for(int i=0;i<n;i++){
if(i==0)
System.out.println(f[i].bianhao+" "+f[i].c+" "+f[i].k);
else if(!(f[i].bianhao==f[i-1].bianhao&&f[i].c==f[i-1].c&&f[i].k==f[i-1].k)){
System.out.println(f[i].bianhao+" "+f[i].c+" "+f[i].k);
}
}
}
} }
class F{
int bianhao,c,k;
F(int bianhao,int c,int k){
this.bianhao=bianhao;
this.c=c;
this.k=k;
}
F(){}
}

NYOJ 8 一种排序(comparator排序)的更多相关文章

  1. php语言实现的7种基本的排序方法

    今天总结了一下常用的7种排序方法,并用php语言实现. 直接插入排序 /* * 直接插入排序,插入排序的思想是:当前插入位置之前的元素有序, * 若插入当前位置的元素比有序元素最后一个元素大,则什么也 ...

  2. Java中几种常见的排序方式

    冒泡排序是一种简单的排序算法.它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成.这个算法的名字 ...

  3. Java中8种常见的排序方法

    排序方法的演示1)插入排序(直接插入排序.希尔排序)2)交换排序(冒泡排序.快速排序)3)选择排序(直接选择排序.堆排序)4)归并排序5)分配排序(基数排序)所需辅助空间最多:归并排序所需辅助空间最少 ...

  4. java讲讲几种常见的排序算法(二)

    java讲讲几种常见的排序算法(二) 目录 java讲讲几种常见的排序算法(一) java讲讲几种常见的排序算法(二) 堆排序 思路:构建一个小顶堆,小顶堆就是棵二叉树,他的左右孩子均大于他的根节点( ...

  5. java讲讲几种常见的排序算法

    java讲讲几种常见的排序算法(一) 目录 java讲讲几种常见的排序算法(一) java讲讲几种常见的排序算法(二) 以数组array={6,3,20,8,15,1}为例 冒泡排序 思路:从第0个到 ...

  6. 用php实现四种常见的排序算法

    几种常见的排序 排序是一个程序员的基本功,对于初级phper,更是可以通过排序算法来锻炼自己的思维能力. 所谓排序,就是对一组数据,按照某个顺序排列的过程.下面就总结四种常用的php排序算法,分别是冒 ...

  7. java几种常见的排序算法总结

    /*************几种常见的排序算法总结***************************/ package paixu; public class PaiXu { final int  ...

  8. javascript中两种基本常用排序算法分析

    备注:内容大部分从网上复制,代码为自己手写.仅做知识的温故知新,并非原创. 1.冒泡排序(Bubble Sort) (1)算法描述 冒泡排序是一种简单的排序算法.它重复地走访过要排序的数列,一次比较两 ...

  9. Java几种常见的排序方法

    日常操作中常见的排序方法有:冒泡排序.快速排序.选择排序.插入排序.希尔排序,甚至还有基数排序.鸡尾酒排序.桶排序.鸽巢排序.归并排序等. 冒泡排序是一种简单的排序算法.它重复地走访过要排序的数列,一 ...

  10. 使用JavaScript几种简单的排序

    前几天在工作碰到一个json对象排序的问题,一直认为JavaScript不能进行对象的排序,其实并不是,今天就来总结下常见的几种简单排序: 第一类 纯数字: var arrOld = [4,10,9, ...

随机推荐

  1. 实现手机端上下左右滑屏的jq原生代码和使用库·两种办法

    先来一个原生的.我使用的是jq. 需要注意的地方就是被触发的元素最好不要是body,这个代码也可以修改,如果obj传进来的是body那么,$(this)必须是你的监听元素,不然会冒泡泡,整个项目就…… ...

  2. Codeforces Round #371 (Div. 1) C - Sonya and Problem Wihtout a Legend

    C - Sonya and Problem Wihtout a Legend 思路:感觉没有做过这种套路题完全不会啊.. 把严格单调递增转换成非严格单调递增,所有可能出现的数字就变成了原数组出现过的数 ...

  3. Could not apply the stored configuration for monitors

    在用户目录下$user.home/.config/monitors.xml,要解决上面的问题,最简单的办法就是删除这个monitors.xml文件,重启一下电脑

  4. springMVC接收参数 xml/json

    springMVC参数接收 作为web层框架,可以接受复杂的类型,且很简单 1.接收字符串可以直接写参数类型,参数名称,跟前端传过来的name值一样即可 如果不一样也可以,通过@RequestPara ...

  5. cogs——2478. [HZOI 2016]简单的最近公共祖先

    2478. [HZOI 2016]简单的最近公共祖先 ★☆   输入文件:easy_LCA.in   输出文件:easy_LCA.out   简单对比时间限制:2 s   内存限制:128 MB [题 ...

  6. ARM开发板搭建NFS网络文件共享方法

    前边 已经提到过吧vmare的IP改成了静态IP,对于上网来说,这个是个麻烦的事.现在重新配置Vmware的IP VMware-Edit-Virtual network editor 选择PC机的无线 ...

  7. 【Java学习】调用ByteBuffer.getInt()方法得到808464432

    调用ByteBuffer.getInt()方法遇到的奇怪错误 最近在参加阿里的中间件比赛,中间用到了RocketMQ的思想,并且主要集中在使用NIO来读写文件.其中遇到了一个很蛋疼的问题,想了半天想不 ...

  8. nyoj 269 VF 动规

    VF 时间限制:1000 ms  |  内存限制:65535 KB 难度:2 描述 Vasya is the beginning mathematician. He decided to make a ...

  9. dp洋洋散散的知识+code

    /*在数轴上有0-N的位置 从0出发每次可以向右走 2 23 233步*/ // 1 总共的方案数 f[i]=f[i-]+f[i-]+f[i-]; f[]=; ;a<=n;a++) { ) f[ ...

  10. Week Five

    2018.12.25 1.[BZOJ 4310] 2.[BZOJ 3879] 3.[BZOJ 2754] 4.[BZOJ 4698] 5.[Codeforces 914E] 6.[Codeforces ...