NYOJ 8 一种排序(comparator排序)
一种排序
- 描述
- 现在有很多长方形,每一个长方形都有一个编号,这个编号可以重复;还知道这个长方形的宽和长,编号、长、宽都是整数;现在要求按照一下方式排序(默认排序规则都是从小到大);
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排序)的更多相关文章
- php语言实现的7种基本的排序方法
今天总结了一下常用的7种排序方法,并用php语言实现. 直接插入排序 /* * 直接插入排序,插入排序的思想是:当前插入位置之前的元素有序, * 若插入当前位置的元素比有序元素最后一个元素大,则什么也 ...
- Java中几种常见的排序方式
冒泡排序是一种简单的排序算法.它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成.这个算法的名字 ...
- Java中8种常见的排序方法
排序方法的演示1)插入排序(直接插入排序.希尔排序)2)交换排序(冒泡排序.快速排序)3)选择排序(直接选择排序.堆排序)4)归并排序5)分配排序(基数排序)所需辅助空间最多:归并排序所需辅助空间最少 ...
- java讲讲几种常见的排序算法(二)
java讲讲几种常见的排序算法(二) 目录 java讲讲几种常见的排序算法(一) java讲讲几种常见的排序算法(二) 堆排序 思路:构建一个小顶堆,小顶堆就是棵二叉树,他的左右孩子均大于他的根节点( ...
- java讲讲几种常见的排序算法
java讲讲几种常见的排序算法(一) 目录 java讲讲几种常见的排序算法(一) java讲讲几种常见的排序算法(二) 以数组array={6,3,20,8,15,1}为例 冒泡排序 思路:从第0个到 ...
- 用php实现四种常见的排序算法
几种常见的排序 排序是一个程序员的基本功,对于初级phper,更是可以通过排序算法来锻炼自己的思维能力. 所谓排序,就是对一组数据,按照某个顺序排列的过程.下面就总结四种常用的php排序算法,分别是冒 ...
- java几种常见的排序算法总结
/*************几种常见的排序算法总结***************************/ package paixu; public class PaiXu { final int ...
- javascript中两种基本常用排序算法分析
备注:内容大部分从网上复制,代码为自己手写.仅做知识的温故知新,并非原创. 1.冒泡排序(Bubble Sort) (1)算法描述 冒泡排序是一种简单的排序算法.它重复地走访过要排序的数列,一次比较两 ...
- Java几种常见的排序方法
日常操作中常见的排序方法有:冒泡排序.快速排序.选择排序.插入排序.希尔排序,甚至还有基数排序.鸡尾酒排序.桶排序.鸽巢排序.归并排序等. 冒泡排序是一种简单的排序算法.它重复地走访过要排序的数列,一 ...
- 使用JavaScript几种简单的排序
前几天在工作碰到一个json对象排序的问题,一直认为JavaScript不能进行对象的排序,其实并不是,今天就来总结下常见的几种简单排序: 第一类 纯数字: var arrOld = [4,10,9, ...
随机推荐
- lr总结
最近一直在用Loardrunner做性能测试,记录下自己在工作中遇到的问题. LR的基本设置 首先是录制,在录制前选择TOOLS-recording options 在General中选择record ...
- 十三oracle --控制结构(分支,循环,控制)
.使用各种if语句2.使用循环语句3.使用控制语句——goto和null(goto语句不推荐使用): 二.条件分支语句pl/sql中提供了三种条件分支语句if—then,if–then–else,if ...
- jquery选择器详细说明
jquery中选择器感觉是用的特别多并且特别方便的一个方法,今天就在这里详细的记载下大多数常用的选择器,一起学习探讨. 首先介绍的是css3的选择器,其中包括了标签选择器(div),ID选择器(#ID ...
- spring配置多数据源——mybatis
这篇文章是配置mybatis多数据源文章,如果是hibernate的话也是没什么影响,配置都是差不多的. 在这家公司上班差不多一星期了,不小心点开配置文件一看这项目配置了两个数据源,蒙了. 之后上网查 ...
- android jni c C++ 实现下载
韩梦飞沙 韩亚飞 313134555@qq.com yue31313 han_meng_fei_sha android jni c C++ 实现下载
- 2017-2018-1 JAVA实验站 第四、五周作业
2017-2018-1 JAVA实验站 第四.五周作业 JAVA实验站小组成员 学号 名字 职务 20162318 张泰毓 组长 20162303 石亚鑫 组员 20162304 张浩林 组员 201 ...
- JBoss 7 配置成windows启动服务
将Jboss7 server 配置成一个windows启动服务的两个文件,部署步骤如下: 1. 先检查是否配置java_home和jboss_home的环境变量,如没配置上先配置,如我的是JBO ...
- bzoj 3172
收获:AC自动机定数组大小时,如果不确定,就定10^6(极限了) /************************************************************** Pro ...
- BZOJ 4443: [Scoi2015]小凸玩矩阵 最大流
4443: [Scoi2015]小凸玩矩阵 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=4443 Description 小凸和小方是好 ...
- hdu 5232 Shaking hands 水题
Shaking hands Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pi ...