java_Java使用Comparable解决排序问题,本文实例讲述了Java使用Comparabl
首先我要解决的是文件解析的问题:
import java.io.BufferedReader; import java.io.FileNotFoundException; import java.io.FileReader; import java.io.IOException; import java.util.ArrayList; import java.util.Arrays; public class forth { public static void main(String[] args) { ArrayList<Person> list=new ArrayList<Person>(); try { FileReader fr=new FileReader("c:\\data.txt"); BufferedReader br=new BufferedReader(fr); String str=null; int num=0; int score=0; int weight=0; int i=0; while((str=br.readLine())!=null) { i++; if(i%5==2) { str=str.trim().substring(4,str.length()-5); num=Integer.parseInt(str); str=br.readLine().trim(); str=str.substring(4,str.length()-5); score=Integer.parseInt(str); i++; str=br.readLine().trim(); str=str.substring(4,str.length()-5); weight=Integer.parseInt(str); i++; Person p=new Person(num,score,weight); list.add(p); } else continue; } } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } Person[] plist=new Person[list.size()]; list.toArray(plist); Arrays.sort(plist); for(int i=0;i<plist.length;i++) { System.out.print(plist[i].getNum()+". " +plist[i].getScore()+" "+plist[i].getWeight()+"\n\r"); } } } class Person implements Comparable<Person>{ private int num; private int weight; private int score; public Person(int num,int score,int weight){ this.num=num; this.score=score; this.weight=weight; } @Override public int compareTo(Person other) { if(this.score>other.score)return -1; else if(this.score<other.score) return 1; else return this.weight>other.weight?1:-1; } public int getNum() { return num; } public void setNum(int num) { this.num = num; } public int getWeight() { return weight; } public void setWeight(int weight) { this.weight = weight; } public int getScore() { return score; } public void setScore(int score) { this.score = score; } }
<p> <no>1</no> <lw>140</lw> <bw>54</bw> </p> <p> <no>2</no> <lw>155</lw> <bw>53</bw> </p> <p> <no>3</no> <lw>140</lw> <bw>42</bw> </p> <p> <no>4</no> <lw>140</lw> <bw>55</bw> </p> <p> <no>5</no> <lw>130</lw> <bw>46</bw> </p>
整体代码:
一次举重竞赛的比赛规则是:选手的成绩以成功举起的总重量来排序,举起总重量多的排在前面;当举起总重量相同时,按照体重来排序,体重轻的排在前面;要求程序读取数据文件作为输入,并按照上述规则排序后,打印出选手编号;数据文件说明如下:现有5名选手,其选手编号、成功举起的总重量及其体重如数据文件data4.txt,样例内容为:
我用一个实体Person来封装这些属性如何把文件内容解析成想要的数据:即提取出每个选手的编号,成绩和体重
本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!
本文地址: https://v30.fanwenzhu.com/jiaob/java/5672.shtml
相关文章
热门TAG
win10 ecshop 主机 阿里云 解决 配置 C# C++ 解析 SQL语句 命令 Go语言 方法 CSS3 HTML5 CSS win7 MSSQL 服务器配置 IIS7.5 IIS7 IIS6 IIS CentOS 7 Linux oracle数据库 oracle phpcms discuz discuz教程最新文章
-
Fitness fitness){ /*double X1=m
时间:2021-01-21
-
所以这里也是需要注意的
时间:2021-01-21
-
hadoop上传文件成果实例代
时间:2021-01-15
-
hadoop负责按key值将map的输
时间:2021-01-15
-
记得勾选springconfig.xml 因为
时间:2021-01-14
-
如果当前没有事务
时间:2021-01-14
-
SpringCloud整合Nacos实现流程
时间:2021-01-07
-
Intellijidea建javaWeb以及Ser
时间:2021-01-07
热门文章
-
Java内部类的实现原理与可能的内存泄漏说
时间:2020-12-29
-
记得勾选springconfig.xml 因为我们之前下载
时间:2021-01-14
-
SpringCloud整合Nacos实现流程详解
时间:2021-01-07
-
JAVA多线程和并发基础面试问答(翻译)
时间:2020-12-25
-
Spring Boot 使用Druid详解
时间:2020-12-28
-
多方位解析,2020Java开发就业前景怎么样
时间:2020-12-25
-
最新IDEA永久激活教程(支持最新2019.2版本
时间:2020-12-25
-
Fitness fitness){ /*double X1=min+0.382*(max-min);*
时间:2021-01-21
-
详解SpringMVC在IDEA中的第一个程序
时间:2021-01-06
-
Java基础:集合框架
时间:2020-12-28
