一种排序

时间限制: 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. C# 6.0 新特性 (三)

    主构造函数 自动属性初始化表达式尤其适合与主构造函数结合使用.主构造函数为降低常见对象模式的繁琐程度提供了一种方法.此功能自五月以来已显著改进.更新包括: 主构造函数的可选实现主体:这将支持此前不受支 ...

  2. phpstorm配置关联php手册

    最近发现有些编辑器可以 选中函数名,通过相应的快捷键就可以调用 浏览器 打开相应 函数的 在线帮助文档. 一番查找,我终于发现 phpStorm 也有相应的功能. 一.自带功能 在编辑器中选中函数名, ...

  3. c++入门笔记

    对于有java基础的人来说,学习c++并不难,毕竟c++是java的前身. 何况还熟练掌握了java呢,哈哈. 安装gcc环境,照着菜鸟教程来. 开发工具ide使用vs,eclipse虽然用习惯了,这 ...

  4. poj1789(prim)

    prim和kruskal都是求解最小生成树的算法.这道题题意就是有N个字符串就是N个节点,而字符串之间的距离就是节点边的长度,求其最小生成树的边权和. 由于是第一次用prim,所以在求安全边的时候采用 ...

  5. 如何配置FastReport.Net环境

    利用FastReport.Net工具箱中的EnvironmentSettings组件可以控制FastReport.Net的环境设置.把EnvironmentSettings组件放到窗体上,并使用下面的 ...

  6. QT学习笔记2:QT中常用函数

    一.QString转number QString number() QString number() QString number() QString number() QString number( ...

  7. luoguP3714 [BJOI2017]树的难题 点分治

    以后传数组绝对用指针... 考虑点分治 在点分的时候,把相同的颜色的在一起合并 之后,把不同颜色依次合并 我们可以用单调队列做到单次合并$O(n + m)$ 如果我们按照深度大小来合并,那么由于每次都 ...

  8. Nginx 常见问题与错误处理

    常见问题与错误处理1. 400 bad request 错误的原因和解决办法配置 nginx.conf 相关设置如下.client_header_buffer_size 16k;large_clien ...

  9. Spring 注解大全与详解

    Spring使用的注解大全和解释 注解 解释 @Controller 组合注解(组合了@Component注解),应用在MVC层(控制层),DispatcherServlet会自动扫描注解了此注解的类 ...

  10. Problem C: 深入浅出学算法004-求多个数的最小公倍数

    Description 求n个整数的最小公倍数 Input 多组测试数据,先输入整数T表示组数 然后每行先输入1个整数n,后面输入n个整数k1 k2...kn Output 求k1 k2 ...kn的 ...