java實(shí)現(xiàn)學(xué)生成績(jī)檔案管理系統(tǒng)
本文實(shí)例為大家分享了java實(shí)現(xiàn)學(xué)生成績(jī)檔案管理系統(tǒng)的具體代碼,供大家參考,具體內(nèi)容如下
實(shí)驗(yàn)要求
• 學(xué)生信息錄入,信息包括學(xué)號(hào)、姓名、專(zhuān)業(yè)、四門(mén)課成績(jī)、總分、名次;
• 系統(tǒng)可對(duì)學(xué)生信息瀏覽、增加、刪除和修改;
• 按學(xué)生成績(jī)確定名次及信息輸出,雙向冒泡排序、希爾排序、快速排序、堆 排序。
• 要求可對(duì)學(xué)生信息查詢(xún),根據(jù)學(xué)號(hào)或姓名進(jìn)行查找;
• 信息修改僅可修改四門(mén)課成績(jī);
• 文件存取學(xué)生信息
實(shí)驗(yàn)設(shè)計(jì)
• 新增學(xué)生信息(包括學(xué)號(hào)、姓名、專(zhuān)業(yè)、4門(mén)課成績(jī)……)
• 瀏覽學(xué)生信息(對(duì)學(xué)生排序后信息進(jìn)行瀏覽)
• 刪除學(xué)生信息(刪除指定學(xué)生的信息,可給用戶(hù)選擇檢索指定項(xiàng))
• 查找學(xué)生信息(查找符合條件的某條記錄)
• 保存學(xué)生信息(保存學(xué)生成績(jī)檔案信息到文本文件)
• 加載學(xué)生信息(登錄系統(tǒng)后將磁盤(pán)文件中保存的學(xué)生成績(jī)信息讀取到內(nèi)存中)
實(shí)驗(yàn)分析
初步分析
本實(shí)驗(yàn)采用dao模式進(jìn)行編寫(xiě),由于暫時(shí)沒(méi)有學(xué)習(xí)數(shù)據(jù)庫(kù),故新建一個(gè)類(lèi)來(lái)模擬保存數(shù)據(jù)庫(kù),此外,本人想法是將數(shù)據(jù)保存于excel文件中,并從excel文件中讀取數(shù)據(jù)。
算法設(shè)計(jì)
快速排序
/**
* 快速排序
* 遞歸
*/
private void quickSort(List<StuInfo> stuInfosList, int left, int right) {
if (left >= right) {
return ;
}
int l = left;
int r = right;
//基準(zhǔn)值,取中間
int key = stuInfosList.get(left).getSum();
boolean flag=true;
//交換容器
StuInfo student;
while (l != r) {
if(flag){
if(key<stuInfosList.get(r).getSum()){
student = stuInfosList.get(r);
stuInfosList.set(r, stuInfosList.get(l));
stuInfosList.set(l, student);
flag=false;
}else{
r--;
}
}else {
if (key>stuInfosList.get(l).getSum()){
student = stuInfosList.get(r);
stuInfosList.set(r, stuInfosList.get(l));
stuInfosList.set(l, student);
flag=true;
}else {
l++;
}
}
}
quickSort(stuInfosList,left, r - 1);
quickSort(stuInfosList, l + 1, right);
}
雙向冒泡排序
/**
* 雙向冒泡排序
*/
private void doubleBubbleSort(List<StuInfo> stuInfosList) {
//設(shè)置一個(gè)交換容器
StuInfo student;
//左右指針
int left = 0, right = stuInfosList.size() - 1;
while (left < right) {
for (int i = left + 1; i <= right; i++) {
if (stuInfosList.get(left).getSum() < stuInfosList.get(i).getSum()) {
student = stuInfosList.get(i);
stuInfosList.set(i, stuInfosList.get(left));
stuInfosList.set(left, student);
}
}
left++;
for (int i = right; i >= left; i--) {
if (stuInfosList.get(right).getSum() > stuInfosList.get(i).getSum()) {
student = stuInfosList.get(i);
stuInfosList.set(i, stuInfosList.get(right));
stuInfosList.set(right, student);
}
}
right--;
}
}
堆排序
/**
* 堆排序
*/
private void heapSort(List<StuInfo> stuInfosList) {
//建堆
buildHeap(stuInfosList);
StuInfo student;
for (int i = stuInfosList.size() - 1; i >= 1; i--) {
//交換
student = stuInfosList.get(i);
stuInfosList.set(i, stuInfosList.get(0));
stuInfosList.set(0, student);
//堆調(diào)整
heapfity(stuInfosList, 0, i - 1);
}
}
/**
* 堆調(diào)整
*/
private void heapfity(List<StuInfo> stuInfosList, int index, int len) {
int lchild = index * 2 + 1;
int rchild = index * 2 + 2;
StuInfo student;
int temp = 0;
if (lchild <= len && rchild <= len) {
temp = stuInfosList.get(lchild).getSum() < stuInfosList.get(rchild).getSum() ? lchild : rchild;
} else if (lchild <= len) {
temp = lchild;
} else if (rchild <= len) {
temp = rchild;
}
//
if (stuInfosList.get(temp).getSum() < stuInfosList.get(index).getSum()) {
student = stuInfosList.get(temp);
stuInfosList.set(temp, stuInfosList.get(index));
stuInfosList.set(index, student);
}
}
/**
* 建立小根堆
*/
private void buildHeap(List<StuInfo> stuInfosList) {
for (int i = stuInfosList.size() / 2 - 1; i >= 0; i--) {
heapfity(stuInfosList, i, stuInfosList.size() - 1);
}
}
希爾排序
/**
* 希爾排序
*/
private void shellSort(List<StuInfo> stuInfosList) {
int step = stuInfosList.size() / 2;
while (step >= 1) {
for (int start = 0; start < step; start++) {
insertSort(stuInfosList, step, start);
}
step /= 2;
}
}
/**
* 希爾排序循環(huán)內(nèi)使用的插入排序
*/
private void insertSort(List<StuInfo> stuInfosList, int step, int start) {
//交換容器
StuInfo student;
for (int i = start + step; i < stuInfosList.size(); i += step) {
for (int j = i; j - step >= 0 && stuInfosList.get(j).getSum() > stuInfosList.get(j - step).getSum(); j -= step) {
student = stuInfosList.get(j);
stuInfosList.set(j, stuInfosList.get(j - step));
stuInfosList.set(j - step, student);
}
}
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Java?GUI實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)
- java學(xué)生成績(jī)管理系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn)
- java實(shí)現(xiàn)學(xué)生成績(jī)錄入系統(tǒng)
- Java模擬登錄正方教務(wù)抓取成績(jī)、課表、空教室
- java用list集合存儲(chǔ)學(xué)生信息并算出成績(jī)平均值操作
- Eclipse+Java+Swing實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)的實(shí)例代碼
- Java實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)
- java實(shí)現(xiàn)學(xué)生成績(jī)信息管理系統(tǒng)
- Java利用條件運(yùn)算符的嵌套來(lái)完成學(xué)習(xí)成績(jī)的劃分
- java實(shí)現(xiàn)簡(jiǎn)單學(xué)生成績(jī)檔案管理系統(tǒng)
相關(guān)文章
Spring 中使用Quartz實(shí)現(xiàn)任務(wù)調(diào)度
這篇文章主要介紹了Spring 中使用Quartz實(shí)現(xiàn)任務(wù)調(diào)度,Spring中使用Quartz 有兩種方式,感興趣的小伙伴們可以參考一下。2017-02-02
Java語(yǔ)法基礎(chǔ)之循環(huán)結(jié)構(gòu)語(yǔ)句詳解
這篇文章主要為大家詳細(xì)介紹了Java語(yǔ)法基礎(chǔ)之循環(huán)結(jié)構(gòu)語(yǔ)句,感興趣的小伙伴們可以參考一下2016-09-09
Zookeeper如何實(shí)現(xiàn)分布式服務(wù)配置中心詳解
Zookeeper在實(shí)際使用場(chǎng)景很多,比如配置中心,分布式鎖,注冊(cè)中心等,下面這篇文章主要給大家介紹了關(guān)于Zookeeper如何實(shí)現(xiàn)分布式服務(wù)配置中心的相關(guān)資料,需要的朋友可以參考下2021-11-11
Java守護(hù)線(xiàn)程實(shí)例詳解_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
在Java中有兩類(lèi)線(xiàn)程:User Thread(用戶(hù)線(xiàn)程)、Daemon Thread(守護(hù)線(xiàn)程) 。下面通過(guò)本文給大家分享java守護(hù)線(xiàn)程實(shí)例詳解,需要的朋友參考下吧2017-06-06
Mybatis中SqlMapper配置的擴(kuò)展與應(yīng)用詳細(xì)介紹(1)
這篇文章主要介紹了Mybatis中SqlMapper配置的擴(kuò)展與應(yīng)用(1)的相關(guān)資料,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下2016-11-11
鴻蒙HarmonyOS App開(kāi)發(fā)造輪子之自定義圓形圖片組件的實(shí)例代碼
這篇文章主要介紹了鴻蒙HarmonyOS App開(kāi)發(fā)造輪子之自定義圓形圖片組件,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01
Activiti7與Spring以及Spring Boot整合開(kāi)發(fā)
這篇文章主要介紹了Activiti7與Spring以及Spring Boot整合開(kāi)發(fā),在Activiti中核心類(lèi)的是ProcessEngine流程引擎,與Spring整合就是讓Spring來(lái)管理ProcessEngine,有感興趣的同學(xué)可以參考閱讀2023-03-03

