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, ...
随机推荐
- C# 6.0 新特性 (三)
主构造函数 自动属性初始化表达式尤其适合与主构造函数结合使用.主构造函数为降低常见对象模式的繁琐程度提供了一种方法.此功能自五月以来已显著改进.更新包括: 主构造函数的可选实现主体:这将支持此前不受支 ...
- phpstorm配置关联php手册
最近发现有些编辑器可以 选中函数名,通过相应的快捷键就可以调用 浏览器 打开相应 函数的 在线帮助文档. 一番查找,我终于发现 phpStorm 也有相应的功能. 一.自带功能 在编辑器中选中函数名, ...
- c++入门笔记
对于有java基础的人来说,学习c++并不难,毕竟c++是java的前身. 何况还熟练掌握了java呢,哈哈. 安装gcc环境,照着菜鸟教程来. 开发工具ide使用vs,eclipse虽然用习惯了,这 ...
- poj1789(prim)
prim和kruskal都是求解最小生成树的算法.这道题题意就是有N个字符串就是N个节点,而字符串之间的距离就是节点边的长度,求其最小生成树的边权和. 由于是第一次用prim,所以在求安全边的时候采用 ...
- 如何配置FastReport.Net环境
利用FastReport.Net工具箱中的EnvironmentSettings组件可以控制FastReport.Net的环境设置.把EnvironmentSettings组件放到窗体上,并使用下面的 ...
- QT学习笔记2:QT中常用函数
一.QString转number QString number() QString number() QString number() QString number() QString number( ...
- luoguP3714 [BJOI2017]树的难题 点分治
以后传数组绝对用指针... 考虑点分治 在点分的时候,把相同的颜色的在一起合并 之后,把不同颜色依次合并 我们可以用单调队列做到单次合并$O(n + m)$ 如果我们按照深度大小来合并,那么由于每次都 ...
- Nginx 常见问题与错误处理
常见问题与错误处理1. 400 bad request 错误的原因和解决办法配置 nginx.conf 相关设置如下.client_header_buffer_size 16k;large_clien ...
- Spring 注解大全与详解
Spring使用的注解大全和解释 注解 解释 @Controller 组合注解(组合了@Component注解),应用在MVC层(控制层),DispatcherServlet会自动扫描注解了此注解的类 ...
- Problem C: 深入浅出学算法004-求多个数的最小公倍数
Description 求n个整数的最小公倍数 Input 多组测试数据,先输入整数T表示组数 然后每行先输入1个整数n,后面输入n个整数k1 k2...kn Output 求k1 k2 ...kn的 ...