Java文件操作(求各专业第一名的学生)
两个文件:info.txt 存放学生基本信息
学号 学院 专业 姓名
1001 计算机学院 软件工程 刘月
1002 生物工程 服装设计 孙丽
score.txt存放分数信息
学号 学科 成绩
1001 数据结构 85
1001 线性代数 89
1002 数据库 100
1002 面料工艺 30
求各学院各专业总分最高的学生。
首先分析,学号--专业是一对一的,一个学生只能属于一个专业,为简单起见, 对于并列第一名的学生,只取第一个。
Student.java
public class Student {
private int id;
private String school;
private String major;
private String name;
public Student()
{
}
public Student(int id,String school,String major,String name)
{
this.id = id;
this.school = school;
this.major = major;
this.name = name;
}
public String toString(){
return this.id +" "+this.school +" "+ this.name+" "+this.major;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getSchool() {
return school;
}
public void setSchool(String school) {
this.school = school;
}
public String getMajor() {
return major;
}
public void setMajor(String major) {
this.major = major;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
PrintTheNo1.java
import java.io.*;
import java.util.HashMap;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.Map;
import java.util.Set; public class PrintTheNo1 { public static void main(String [] args) throws IOException
{
try{
LinkedList<Student> stuList =getStuList();
HashMap<Integer,Double> map = getSumScoreOfStudent();
getTopStu(stuList,map);
}catch(IOException io)
{
System.out.println("出错了呀!"+io);
}
}
//读取info文件
public static LinkedList<Student> getStuList() throws IOException
{
String oneLine;
try{
FileReader a = new FileReader("D:\\NewPro\\Files\\info.txt");
BufferedReader br = new BufferedReader(a);
int line = 0;
LinkedList<Student> stuList = new LinkedList<Student>();
while((oneLine = br.readLine() )!= null)
{
//从文件的第二行开始读取数据
line++;
if(line == 1) continue;
else
{
String[] info = oneLine.split(" ");
Student stu = new Student(Integer.parseInt(info[0]),(String)info[1],(String)info[2],(String)info[3]);
stuList.add(stu);
}
}
for(Student s:stuList)
System.out.println(s.toString());
br.close();
return stuList;
}catch(IOException io)
{
System.out.println("error@"+io);
return null;
}
} //求各个学生的总分
public static HashMap<Integer,Double> getSumScoreOfStudent() throws IOException
{
HashMap<Integer,Double> map = new HashMap<Integer,Double>();
String oneLine;
try{ FileReader a = new FileReader("D:\\NewPro\\Files\\score.txt");
BufferedReader br = new BufferedReader(a);
int line = 0;
double sum = 0; while((oneLine = br.readLine() )!= null)
{
++line;
if(line == 1) continue;
else
{
String [] info = oneLine.split(" ");
int id = Integer.parseInt(info[0]);
if(map.containsKey(id))
{
sum = map.get(id)+Double.parseDouble(info[2]);
map.put(id,sum);
}
else
map.put(id,Double.parseDouble(info[2]));
}
} return map; }catch(IOException io)
{
System.out.println("error in score.txt"+io);
return null;
}
}
//各个专业第一名的学生
public static void getTopStu(LinkedList<Student> stuList,HashMap<Integer,Double> map)
{
Student s = new Student();
int id =0;
double score = 0;
double maxScore = 0;
String major;
//MajorAndScore保存专业--最高分
HashMap<String,Double> MajorAndScore = new HashMap<String,Double>();
//result保存 专业--学号,然后遍历result,根据result的学号值找到Student信息,保存到topStudent链表中。
HashMap<String,Integer> result = new HashMap<String,Integer>();
LinkedList<Student> topStudent = new LinkedList<Student>(); if(stuList.size() == 0 || map.size() ==0 )
return;
for(int i=0;i<stuList.size();i++)
{
s = stuList.get(i);
id =s.getId();
score = map.get(id);//拿到该学生的总分
major = s.getMajor();
if(map.containsKey(id) )
{
if(MajorAndScore.containsKey(major) && score > maxScore)
//如果已经有major.且当前学生的总分更大一些,把更大的分数加进去
{
maxScore = score;
MajorAndScore.put(major,maxScore);
result.put(major,id); } else if(!MajorAndScore.containsKey(major))
//如果不存在major key
{
MajorAndScore.put(major,score);
result.put(major,id); }
else
{
map.remove(id);
}
}
}
@SuppressWarnings("rawtypes")
Set st = result.entrySet();
Iterator it =st.iterator();
while(it.hasNext())
{ Map.Entry entry = (Map.Entry)it.next();
topStudent.add(getById(stuList,(Integer)entry.getValue()));
} System.out.println( "各专业第一名是: ");
for(int i=0;i<topStudent.size();i++)
{ System.out.println(topStudent.get(i).toString());
} } //根据id找到学生信息
private static Student getById(LinkedList<Student> stuList,int id)
{
for(int i=0;i<stuList.size();i++)
{
if(stuList.get(i).getId() == id)
{
return stuList.get(i);
}
}
return null;
} }
Java文件操作(求各专业第一名的学生)的更多相关文章
- Java文件操作源码大全
Java文件操作源码大全 1.创建文件夹 52.创建文件 53.删除文件 54.删除文件夹 65.删除一个文件下夹所有的文件夹 76.清空文件夹 87.读取文件 88.写入文件 99.写入随机文件 9 ...
- 14、Java文件操作stream、File、IO
1.文件操作涉及到的基本概念 File File类 是文件操作的主要对象中文意义就是 文件 顾名思意 万物皆文件,在计算上看到的所有东西都是文件保存,不管是你的图片.视频.数据库数据等等都是按照基本的 ...
- Java 文件操作大全
Java 文件操作大全 //1.创建文件夹 //import java.io.*; File myFolderPath = new File(str1); try { if (!myFolderPat ...
- JAVA文件操作类和文件夹的操作代码示例
JAVA文件操作类和文件夹的操作代码实例,包括读取文本文件内容, 新建目录,多级目录创建,新建文件,有编码方式的文件创建, 删除文件,删除文件夹,删除指定文件夹下所有文件, 复制单个文件,复制整个文件 ...
- java文件操作(普通文件以及配置文件的读写操作)
转自:java文件操作(普通文件以及配置文件的读写操作) 读取普通文件 : /** * xiangqiao123欢迎你 如果对代码有疑问可以加qq群咨询:151648295 * * 读取MyFile文 ...
- Java文件操作API功能与Windows DOS命令和Linux Shell 命令类比
Java文件操作API功能与Windows DOS命令和Linux Shell 命令类比: Unix/Linux (Bash) Windows(MS-DOS) Java 进入目录 cd cd - 创建 ...
- java 文件操作(二)---Files和Path
自从java 7以来,引入了FIles类和Path接口.他们两封装了用户对文件的所有可能的操作,相比于java 1的File类来说,使用起来方便很多.但是其实一些本质的操作还是很类似的.主要需要知道的 ...
- Java文件操作类效率对比
前言 众所周知,Java中有多种针对文件的操作类,以面向字节流和字符流可分为两大类,这里以写入为例: 面向字节流的:FileOutputStream 和 BufferedOutputStream 面向 ...
- Java文件操作系列[2]——使用JXL操作Excel文件
由于java流无法实现对Excel文件的读写操作,因此在项目中经常利用第三方开源的组件来实现.支持Excel文件操作的第三方开源组件主要有Apache的POI和开源社区的JXL. 总体来说,二者的区别 ...
随机推荐
- MySQL怎么缓解读的压力的?---buffer pool
每当我们想要缓解读,一般会想到什么? 预读取,缓存 缓存 缓存,其实就是将高频访问的数据放到内存里面,减少读盘的次数. 为了提高内存的利用率,MySQL还建立了缓存池,也就是buffer pool,存 ...
- win10+MX350显卡+CUDA10.2+PyTorch 安装过程记录 深度学习环境配置
https://blog.csdn.net/m0_37867091/article/details/105788637
- Jenkins+SVN+Maven+testNG管理项目
1.登录访问:http://localhost:8080/jenkins 2.系统管理 => 全局工具配置 => ADD JDK AND Add Maven 3.安装SVN插件:系统管 ...
- js中的特数值-null-undefined-NaN
一.补充 1.js中的三大特殊数据:undefined.null.NaN NaN :非法的数值运算得到的结果 特殊之处: 是一个数值型数据,但不是一个数字 NaN不等于任何值,和任何数据都不相等,Na ...
- 使用 SSL 加密的 JDBC 连接 SAP HANA 数据库
近期客户为满足安全要求,提了让业务应用使用 SSL 方式连接 SAP HANA 数据库的需求.本人查询 SAP官方文档 发现数据库支持 SSL 连接,有参数直接加到 JDBC 的 URL 后边就行了, ...
- 用C++实现俄罗斯方块(Tetris)游戏
我是一个C++初学者,控制台实现了一个俄罗斯方块游戏. 代码如下: //"俄罗斯方块"V1.0 //李国良于2017年1月20日编写完成 #include <iostream ...
- MySQL配置参数innodb_flush_log_at_trx_commit
innodb_flush_log_at_trx_commit 此参数有3个值可设置:0.1.2 0表示每秒刷写一次日志到硬盘,极端情况下MySQL或操作系统挂了最多丢1秒的数据更新 1表示每次事务提交 ...
- [Aizu1410]Draw in Straight Lines
注意到当操作确定后,显然操作顺序总是涂黑色的1操作->涂白色的1操作->2操作 用$b/w_{r/c}(i,j)$表示$(i,j)$是否被黑色/白色 横着/竖着 涂过(1表示涂过,0表示没 ...
- [loj3347]有趣的旅途
考虑求出重心,以0为根建树,求出第 $i$个点的子树大小$sz[i]$($a(0,i)$),则满足$n-sz[i]\le \lfloor\frac{n}{2}\rfloor$的$sz[i]$中的最小值 ...
- SSM整合小项目
1.文件目录结构 2.MyBatis配置 创建数据库环境 CREATE DATABASE `ssmbuild`; USE `ssmbuild`; DROP TABLE IF EXISTS `books ...