学生成绩管理系统(C语言实现)

设计并实现一个简单的学生成绩管理系统

学生成绩表信息包括学号、姓名、各科课程成绩(语文、数学、英语、政治)和总分。用带头结点的单链表管理学生成绩表,每个学生的信息依次从键盘输入,并根据需要进行插入、删除、排序、输出等操作。

一、实训环境

信息工程学院双创交流中心******电脑室开展实训,由企业老师带领我们复习C语言的基本知识,然后讲解学生成绩管理系统各个组件功能的构成部分,以及每部分的代码详解。

二、项目开发过程

1. 学生成绩管理系统主页面功能全览

#include<iostream>
#include<stdio.h>
#include<stdlib.h> 
#include<string.h>
using namespace std;
typedef struct PNode*LinkList;
typedef struct PNode{
	int stdio;
	char name[30];
	double chinese;
	double math;
	double english;
	double politics;
	double sum;
	PNode *next;
}PNode;

int main(){	
    LinkList llist=(LinkList)malloc(sizeof(PNode));
    llist->next=NULL;
	int a,b=1;
	while(b){
		printf("\n-----------------------学生成绩管理系统-----------------------\n");
		printf("请选择你需要的功能:\n");
		printf(" 1.查找     2.插入    3.排序     4.展示     5.删除     6.退出\n");
		scanf("%d",&a);
		switch(a){
			case 1:printf("\n-----------------------学生成绩查找功能-----------------------\n"); check(llist);break;
			case 2:printf("\n-----------------------学生成绩插入功能-----------------------\n"); input(llist);break; 
			case 3:printf("\n-----------------------学生成绩排序功能-----------------------\n"); sortList(llist);break;
			case 4:printf("\n-----------------------学生成绩展示功能-----------------------\n"); display(llist);break; 
			case 5:printf("\n-----------------------学生成绩删除功能-----------------------\n"); deleteList(llist);break; 
			case 6:b = 0; break; 
			default:printf("输入有误!请重新输入!\n");
		}	
	}
	printf("\n-----------------------已退出成绩管理系统-----------------------\n"); 
	return 0;
}

2.输入学生信息,按输入顺序建立一个带头结点的单链表,直到输入学号为0结束。

void input(LinkList llist){
	printf("请输入考试的学生人数:\n");
	int n;scanf("%d",&n);
	LinkList p;
	for(int i=1;i<=n;i++){
		p=(LinkList)malloc(sizeof(PNode));
		printf("请输入学生学号:\n");
		scanf("%d",&p->stdio);
		
		printf("请输入学生姓名:\n");
		scanf("%s",p->name);
		
		printf("请输入学生语文成绩:\n");
		scanf("%lf",&p->chinese);
		
		printf("请输入学生数学成绩:\n");
		scanf("%lf",&p->math);
		
		printf("请输入学生英语成绩:\n");
		scanf("%lf",&p->english);
		
		printf("请输入学生政治成绩:\n");
		scanf("%lf",&p->politics);
		
		p->sum=p->chinese+p->math+p->english+p->politics;
		p->next=llist->next;
		llist->next=p;
	}
	printf("\n-----------------------学生成绩完成录入-----------------------\n");
} 

3.输入一个学生的姓名,在链表中进行查找,如果存在,显示该生的所有信息;如果不存在,显示提示信息“查无此人”。

void check(LinkList llist){
	LinkList e=llist->next; 
    int f;
    printf("请输入查找的学号:\n");
    scanf("%d",&f);
    while(e->stdio!=f)
    e=e->next;
	if(e->stdio==f) 
	printf("%d\t %s%12lf %6lf %6lf %6lf %6lf\n",e->stdio,e->name,e->chinese,e->math,e->english,e->politics,e->sum);
	else
	printf("查找值不存在!\n");
}

4.展示链表中所输入的全部学生信息。

void display(LinkList llist){
	printf("\n-----------------------学生成绩信息展示-----------------------\n");
	printf("学号\t姓名\t 语文\t  数学\t  英语\t    政治    总分\n"); 
	LinkList p=llist->next;
	if(llist->next==NULL){
		printf("系统中无学生信息!\n");
	}
	else{
		while(p!=NULL){ 
		printf(" %d\t %s%12lf %6lf %6lf %6lf %6lf\n",p->stdio,p->name,p->chinese,p->math,p->english,p->politics,p->sum);
		p=p->next;} 
	}
	printf("\n-----------------------学生成绩完成展示-----------------------\n");
}

5. 将学生成绩按总成绩从低到高排序,并输出结果。

void sortList(LinkList llist){ 
	printf("请输入排序的依据:\n");
	printf("1.数学    2.语文   3.英语    4.政治    5.总分\n");
	int a;
	scanf("%d",&a);
	switch(a){
		case 1:
			printf("按照数学排序已完成\n");
			if(llist->next==NULL){
		printf("学生成绩无数据!"); 
	} else if(llist->next->next==NULL){
		printf("学生成绩为一个,无需排序!"); 
	}else{
		LinkList p=llist->next->next;
		llist->next->next=NULL;
		LinkList q,r;
		while(p!=NULL){
			q=llist;
			r=p->next;
			while(q->next!=NULL&&q->next->math<p->math){
				q=q->next;
			}
			p->next=q->next;
			q->next=p;
			p=r;
		}
	}
			break;
		case 2:
			printf("按照语文排序已完成\n");
			if(llist->next==NULL){
		printf("学生成绩无数据!"); 
	} else if(llist->next->next==NULL){
		printf("学生成绩为一个,无需排序!"); 
	}else{
		LinkList p=llist->next->next;
		llist->next->next=NULL;
		LinkList q,r;
		while(p!=NULL){
			q=llist;
			r=p->next;
			while(q->next!=NULL&&q->next->chinese<p->chinese){
				q=q->next;
			}
			p->next=q->next;
			q->next=p;
			p=r;
		}
	}
			break;
		case 3:
			printf("按照英语排序已完成\n");
			if(llist->next==NULL){
		printf("学生成绩无数据!"); 
	} else if(llist->next->next==NULL){
		printf("学生成绩为一个,无需排序!"); 
	}else{
		LinkList p=llist->next->next;
		llist->next->next=NULL;
		LinkList q,r;
		while(p!=NULL){
			q=llist;
			r=p->next;
			while(q->next!=NULL&&q->next->english<p->english){
				q=q->next;
			}
			p->next=q->next;
			q->next=p;
			p=r;
		}
	}
			break;
		case 4:
			printf("按照政治排序已完成\n");
			if(llist->next==NULL){
		printf("学生成绩无数据!"); 
	} else if(llist->next->next==NULL){
		printf("学生成绩为一个,无需排序!"); 
	}else{
		LinkList p=llist->next->next;
		llist->next->next=NULL;
		LinkList q,r;
		while(p!=NULL){
			q=llist;
			r=p->next;
			while(q->next!=NULL&&q->next->politics<p->politics){
				q=q->next;
			}
			p->next=q->next;
			q->next=p;
			p=r;
		}
	}
			break;
		case 5:
			printf("按照总分排序已完成\n");
			if(llist->next==NULL){
		printf("学生成绩无数据!"); 
	} else if(llist->next->next==NULL){
		printf("学生成绩为一个,无需排序!"); 
	}else{
		LinkList p=llist->next->next;
		llist->next->next=NULL;
		LinkList q,r;
		while(p!=NULL){
			q=llist;
			r=p->next;
			while(q->next!=NULL&&q->next->sum<p->sum){
				q=q->next;
			}
			p->next=q->next;
			q->next=p;
			p=r;
		}
	}
			break;
		default:
			printf("输入有误!\n"); 
	}
}

6. 输入一个学生的学号,如果链表中存在该学生信息,则将其删除。

void deleteList(LinkList llist){ 
    LinkList p=llist; 
    int d;
	printf("请输入删除的学号:\n");
	scanf("%d",&d);
    while(p!=NULL){
	if(p->next->stdio!=d) p=p->next;break;}
	if(p->next->stdio==d) p->next=p->next->next;
	else
	printf("删除值不存在!\n");	
	printf("\n-----------------------学生成绩完成删除-----------------------\n");
}

 

  • 113
    点赞
  • 1006
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 31
    评论
学生成绩管理系统是一个用于记录和管理学生成绩的系统。下面是两个C语言实现学生成绩管理系统的例子: 1. 使用结构体数组实现学生成绩管理系统: ```c #include <stdio.h> #include <string.h> struct student { int num; char name[20]; float pingshi; float shiyan; float kaoshi; float total; }; int main() { struct student stu[100]; int count = 0; char end[] = "end"; printf("请输入学生信息(输入end结束):\n"); while (1) { printf("学号:"); scanf("%d", &stu[count].num); if (strcmp(stu[count].num, end) == 0) { break; } printf("姓名:"); scanf("%s", stu[count].name); printf("平时成绩:"); scanf("%f", &stu[count].pingshi); printf("实验成绩:"); scanf("%f", &stu[count].shiyan); printf("考试成绩:"); scanf("%f", &stu[count].kaoshi); stu[count].total = stu[count].pingshi + stu[count].shiyan + stu[count].kaoshi; count++; } printf("\n学生成绩如下:\n"); printf("学号\t姓名\t平时成绩\t实验成绩\t考试成绩\t总成绩\n"); for (int i = 0; i < count; i++) { printf("%d\t%s\t%.2f\t%.2f\t%.2f\t%.2f\n", stu[i].num, stu[i].name, stu[i].pingshi, stu[i].shiyan, stu[i].kaoshi, stu[i].total); } return 0; } ``` 2. 使用函数实现学生成绩管理系统: ```c #include <stdio.h> #include <string.h> struct student { int num; char name[20]; float pingshi; float shiyan; float kaoshi; float total; }; void input(struct student *stu) { printf("学号:"); scanf("%d", &stu->num); printf("姓名:"); scanf("%s", stu->name); printf("平时成绩:"); scanf("%f", &stu->pingshi); printf("实验成绩:"); scanf("%f", &stu->shiyan); printf("考试成绩:"); scanf("%f", &stu->kaoshi); stu->total = stu->pingshi + stu->shiyan + stu->kaoshi; } void output(struct student *stu) { printf("%d\t%s\t%.2f\t%.2f\t%.2f\t%.2f\n", stu->num, stu->name, stu->pingshi, stu->shiyan, stu->kaoshi, stu->total); } int main() { struct student stu[100]; int count = 0; char end[] = "end"; printf("请输入学生信息(输入end结束):\n"); while (1) { input(&stu[count]); if (strcmp(stu[count].name, end) == 0) { break; } count++; } printf("\n学生成绩如下:\n"); printf("学号\t姓名\t平时成绩\t实验成绩\t考试成绩\t总成绩\n"); for (int i = 0; i < count; i++) { output(&stu[i]); } return 0; } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 31
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Meteor.792

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值