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. 总体来说,二者的区别 ...
随机推荐
- 文件与文件系统的压缩与打包 tar gzip bzip2
1:linux下常见的压缩文件后缀: .gz .zip .bz2 打包后的: .tar.gz .tar.zip .tar.bz2 2:gzip: 压缩:gzip file 解压:gunzip file ...
- IDEA中Update resources和Update classes and resources、Redeploy、Restart server的区别
选项 描述 update resources 所有更改的资源都会更新(HTML,JSP,JavaScript,CSS和图像文件) update classes and resources 更改的资源将 ...
- vue 快速入门 系列 —— 使用 vue-cli 3 搭建一个项目(上)
其他章节请看: vue 快速入门 系列 使用 vue-cli 3 搭建一个项目(上) 前面我们已经学习了一个成熟的脚手架(vue-cli),笔者希望通过这个脚手架快速搭建系统(或项目).而展开搭建最好 ...
- 使用Adobe Acrobat进行Word转PDF遇到的问题及解决方法
软件版本:Adobe Acrobat 9 Pro 使用场景:Word转PDF 问题1: 我以为先要在Adobe Acrobat 9 Pro中打开Word文件,然后在执行类似转换/导出操作.但是始终无法 ...
- Python基础(map/reduce)
from functools import reduce#reduce函数在python3的内建函数移除了,放入了functools模块 #map() list1 = [1,2,3,4,5,6,7,8 ...
- Django 小实例S1 简易学生选课管理系统 1 项目流程梳理与数据库设计
Django 小实例S1 简易学生选课管理系统 第1章--项目流程梳理与数据库设计 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 1 项目流程梳理 ...
- 深入理解Spring IOC源码分析
Spring容器初始化 本文使用的是Spring 5.1.7版本 写在前面:我们看源码一般有3种方式. 第一种直接用class文件,IDEA会帮我们反编译成看得懂的java代码 第二种是用maven的 ...
- [hdu7074]Little prince and the garden of roses
显然每种颜色的花是独立的,可以分别求出答案后取$\max$ 对于某种颜色$C$,建立一张二分图,左右分别为$n$行$n$列,且第$i$行和第$j$列有边当且仅当$c_{i,j}=C$ 此时,问题即对边 ...
- [atAGC051D]C4
考虑将两次移动作为一个整体,两次移动的效果分为:$s-u$.$u-s$和原地不动 对于从$s$回到$s$路径,必然有前两种效果使用次数相同,假设都为$i$(枚举),那么原地不动的次数$j=\frac{ ...
- 『与善仁』Appium基础 — 14、Appium测试环境搭建
目录 1.Appium测试环境搭建整体思路 (1)Android测试环境搭建 (2)Appium测试环境搭建 (3)测试脚本语言的环境搭建 2.Appium在Android端和IOS端的工作流程 (1 ...