c语言课设学生管理程序,数据结构课设-学生管理系统C语言

2023-12-17 16:40

本文主要是介绍c语言课设学生管理程序,数据结构课设-学生管理系统C语言,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

我在大二上学期期末时候写的,大概2014年1月5号左右。我写在博客里一是为我以后复习所用,二是希望对需要的人有所帮助。

问题描述:

现有学生成绩文本文件1(1.txt)和文件2(2.txt)。文件数据按学好排序。文件格式如下:

姓名     学号      C语言  英语      高数

张三     001        87          76          65

李四     002        89          90          96

王五     003        66          54          39

写一个程序,实现对两个文件数据的合并,生成新文件3.txt,文件3.txt中的数据按总分降序排序。

#include

#include

#include

#include "iostream"

using namespace std;

#define MAXLIN 40

//一个学生结构体存储结构

typedef struct Stu{

char name[18];                //名字

char num[18];                    //学号

char C[18];                        //C语言成绩

char E[18];                        //英语成绩

char M[18];                        //高数成绩

int sum;                    //成绩总和

int t;                        //名次

struct Student *next;

}Stu;

int o;

void substring(char *s,int i,int n,char *t)                    //截取指定位置的 字符串子串

{

int j=0;

for(;j

t[j]=s[i++];

t[j]=0;

}

void Read(Stu stu[40],char str[20])            //从txt 1  2文档中 读取 数据 并进行 处理

{

FILE *fp;

int t=0;

char haha[26]={"NULL"};

char hehe[18];

char hehe2[18];

if((fp=fopen(str,"rt"))==NULL)

{

printf("can not open the file\n");

exit(0);

}

fgets(haha,27,fp);

printf("%s",haha);

while(fgets(hehe,18,fp)!=NULL)

{

substring(hehe,0,4,hehe2);

strcpy(stu[o].name,hehe2);

substring(hehe,5,3,stu[o].num);

substring(hehe,9,2,stu[o].C);

substring(hehe,12,2,stu[o].E);

substring(hehe,15,2,stu[o].M);

printf("%s\t",stu[o].name);

printf("%s\t",stu[o].num);

printf("%s\t",stu[o].C);

printf("%s\t",stu[o].E);

printf("%s\n",stu[o].M);

fgets(hehe,18,fp);

o++;

}

fclose(fp);

printf("\n");

}

void enen(Stu stu[40])                //对  从文档 1 2  中 取出 的学生 成绩 数据 进行 排序

{

int a,b;

for(int i=0;i

{

a=stu[i].C[0]-'0';            //-'0'是 把 字符 转换为 数字

b=stu[i].C[1]-'0';

stu[i].sum=a*10+b;

a=stu[i].E[0]-'0';

b=stu[i].E[1]-'0';

stu[i].sum+=a*10+b;

a=stu[i].M[0]-'0';

b=stu[i].M[1]-'0';

stu[i].sum+=a*10+b;

}

for(i=0;i

{

int y=1;

for(int j=0;j

{

if(stu[i].sum

y++;

}

for(j=i+1;j

{

if(stu[i].sum

y++;

}

stu[i].t=y;

}

printf("姓名    学号    C语言    英语    高数    总分    名次\n");

for(int k=0;k

printf("%s    %s    %s    %s    %s    %d    %d\n",stu[k].name,stu[k].num,stu[k].C,stu[k].E,stu[k].M,stu[k].sum,stu[k].t);

printf("排序完毕!\n\n");

}

//生成文档3.txt

void Create(Stu stu[40])                                //生成 3.txt文档

{

char haha[26]={"姓名    学号    C语言    英语    高数"};

FILE *fp1;

char hehe1[5]={"\t"};

char hehe2[5]={"\n"};

if((fp1=fopen("E:\\3.txt","w+"))==NULL)

{

printf("can not open the file\n");

exit(0);

}

fputs(haha,fp1);

fputs(hehe2,fp1);

for(int i=1;i<=o;i++)                //将学生相关信息 输入到 3.txt文档中

for(int j=0;j

{

if(stu[j].t==i)

{

fputs(stu[j].name,fp1);

fputs(hehe1,fp1);

fputs(stu[j].num,fp1);

fputs(hehe1,fp1);

fputs(stu[j].C,fp1);

fputs(hehe1,fp1);

fputs(stu[j].E,fp1);

fputs(hehe1,fp1);

fputs(stu[j].M,fp1);

fputs(hehe1,fp1);

fputs(hehe2,fp1);

}

}

fclose(fp1);

printf("已经按总成绩降序排好顺序,并存入到了3.txt文件里!\n\n");

}

//输出文档3数据

void OutPut(Stu stu[])                    //把已经存入到 3.txt中的 学生信息 输出来

{

FILE *fp;

int t=0;

char haha[26]={"NULL"};

char hehe[18];

char hehe2[18];

if((fp=fopen("E:\\3.txt","rt"))==NULL)

{

printf("can not open the file\n");

exit(0);

}

fgets(haha,27,fp);

printf("%s",haha);

while(fgets(hehe,18,fp)!=NULL)

{

substring(hehe,0,4,hehe);

printf("%s\t",hehe);

substring(hehe,5,3,hehe2);

printf("%s\t",hehe2);

substring(hehe,9,2,hehe2);

printf("%s\t",hehe2);

substring(hehe,12,2,hehe2);

printf("%s\t",hehe2);

substring(hehe,15,2,hehe2);

printf("%s\t",hehe2);

for(int k=0;k

{

if(strcmp(hehe,stu[k].name)==0)

printf("%d\t%d\n",stu[k].sum,stu[k].t);

}

fgets(hehe,18,fp);

t++;

}

fclose(fp);

printf("文件3.txt输出完毕!");

printf("\n\n");

}

//退出

void TuiChu()

{

printf("谢谢使用!\n\n");

}

//主函数

int main()

{

int choice;

Stu stu[MAXLIN];

char str1[20]={"E:\\1.txt"};

char str2[20]={"E:\\2.txt"};

while(true)

{

printf("**********欢迎使用学生成绩管理程序**********\n");

printf("*****读取学生文档 1.txt 数据 请输入:  1*****\n");

printf("*****读取学生文档 2.txt 数据 请输入:  2*****\n");

printf("*****对学 生总成绩排序       请输入:  3*****\n");

printf("*****生成学生文档 3.txt      请输入:  4*****\n");

printf("*****输出学生文档 3.txt      请输入:  5*****\n");

printf("*****退出请输入                       0*****\n");

printf("请输入您的选择:");

scanf("%d",&choice);

if(choice<0||choice>5)

{

printf("请输入0~5之间的数字!请重新输入!\n\n");

continue;

}

switch(choice)

{

case 1:        Read(stu,str1);

break;

case 2:        Read(stu,str2);

break;

case 3:        enen(stu);

break;

case 4:        Create(stu);

break;

case 5:        OutPut(stu);

break;

case 0:        TuiChu();

exit(0);

}

}

return 0;

}

6.测试结果

6.1读取文件1.txt信息部分用户界面

0818b9ca8b590ca3270a3433284dd417.png

图6.1读取文件1.txt信息用户界面

6.2读取文件2.txt信息用户界面

0818b9ca8b590ca3270a3433284dd417.png

图6.2读取文件2.txt信息用户界面

6.3学生成绩排序部分用户界面

0818b9ca8b590ca3270a3433284dd417.png

图 6.3 学生成绩排序用户界面

6.4往3.txt输入学生成绩用户界面

0818b9ca8b590ca3270a3433284dd417.png

图 6.4往3.txt输入学生成绩用户界面

6.5读取文件3.txt信息用户界面

0818b9ca8b590ca3270a3433284dd417.png

图 6.5读取文件3.txt信息用户界

1.txt 里面数据:

姓名    学号    C语言    英语    高数

张三    001    76    34    45

李四    002    25    45    67

王二    003    78    34    67

郑秀    007    87    98    89

2.txt里面数据

姓名    学号    C语言    英语    高数

黄宏    010    87    76    46

巩俐    011    56    45    87

牛群    012    45    78    45

排序后的3.txt文档数据

姓名    学号    C语言    英语    高数 郑秀    007    87    98    89     黄宏    010    87    76    46     巩俐    011    56    45    87     王二    003    78    34    67     牛群    012    45    78    45     张三    001    76    34    45     李四    002    25    45    67

这篇关于c语言课设学生管理程序,数据结构课设-学生管理系统C语言的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/505081

相关文章

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧

工厂ERP管理系统实现源码(JAVA)

工厂进销存管理系统是一个集采购管理、仓库管理、生产管理和销售管理于一体的综合解决方案。该系统旨在帮助企业优化流程、提高效率、降低成本,并实时掌握各环节的运营状况。 在采购管理方面,系统能够处理采购订单、供应商管理和采购入库等流程,确保采购过程的透明和高效。仓库管理方面,实现库存的精准管理,包括入库、出库、盘点等操作,确保库存数据的准确性和实时性。 生产管理模块则涵盖了生产计划制定、物料需求计划、

《数据结构(C语言版)第二版》第八章-排序(8.3-交换排序、8.4-选择排序)

8.3 交换排序 8.3.1 冒泡排序 【算法特点】 (1) 稳定排序。 (2) 可用于链式存储结构。 (3) 移动记录次数较多,算法平均时间性能比直接插入排序差。当初始记录无序,n较大时, 此算法不宜采用。 #include <stdio.h>#include <stdlib.h>#define MAXSIZE 26typedef int KeyType;typedef char In

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

如何确定 Go 语言中 HTTP 连接池的最佳参数?

确定 Go 语言中 HTTP 连接池的最佳参数可以通过以下几种方式: 一、分析应用场景和需求 并发请求量: 确定应用程序在特定时间段内可能同时发起的 HTTP 请求数量。如果并发请求量很高,需要设置较大的连接池参数以满足需求。例如,对于一个高并发的 Web 服务,可能同时有数百个请求在处理,此时需要较大的连接池大小。可以通过压力测试工具模拟高并发场景,观察系统在不同并发请求下的性能表现,从而