C語言實(shí)現(xiàn)簡(jiǎn)單班級(jí)成績(jī)管理系統(tǒng)
前言:
有朋友最近在做c語言課設(shè),要求寫一個(gè)班級(jí)成績(jī)管理系統(tǒng),便寫份簡(jiǎn)單的代碼來玩。代碼原創(chuàng),未參考任何其他人的代碼
程序要求

說明
- 本程序主要采用結(jié)構(gòu)體數(shù)組
- 本文件采用多文件編寫,由于程序規(guī)模小,故未采用編寫頭文件的方式
- 使用 #pragma once 來防止頭文件重復(fù)包含
代碼
怎么使用本程序看看注釋應(yīng)該就知道了。run main.c 就行。其他各文件作用:
- def.c 定義了一些常量和全局變量,結(jié)構(gòu)體
- myIO.c 實(shí)現(xiàn)了成績(jī)錄入和成績(jī)打印輸出
- file.c 實(shí)現(xiàn)了將成績(jī)保存為文件
- menu.c 實(shí)現(xiàn)了菜單功能
- function.c 包含其他一些要用的函數(shù)
main.c
#include "menu.c"
int main()
{
? ? select();
? ? return 0;
}def.c
// 相同頭文件只包含一次,后不贅述
#pragma once
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define OK 1
#define ERROR 0
#define TRUE 1
#define FALSE 0
#define Status int
// 課程
typedef struct Course
{
? ? char name[30];
? ? int score;
} Course, *pCourse;
// 學(xué)生
typedef struct Student
{
? ? char number[30];
? ? char name[30];
? ? pCourse pC;
} Student, *pStudent;
// n是學(xué)生數(shù), m是課程數(shù)
int n, m;
char courseName[30], studentName[30], course[20][30];
pStudent pS = NULL;myIO.c
#pragma once
#include "def.c"
pStudent inputStudentInfo(void);
void printStudentInfo(pStudent pS);
// 錄入學(xué)生信息
pStudent inputStudentInfo(void)
{
? ? int i, j;
? ? printf("Please input the number of students and courses: ");
? ? scanf("%d %d", &n, &m);
? ? printf("Please input the name of courses: ");
? ? for (i = 0; i < m; i++)
? ? {
? ? ? ? scanf("%s", course[i]);
? ? }
? ? pStudent pS = (pStudent)malloc(sizeof(Student) * n);
? ? if (!pS)
? ? ? ? return NULL;
? ? printf("Please input the info: \n");
? ? for (i = 0; i < n; i++)
? ? {
? ? ? ? pS[i].pC = (pCourse)malloc(sizeof(Course) * m);
? ? ? ? if (!pS[i].pC)
? ? ? ? ? ? return NULL;
? ? ? ? scanf("%s %s", pS[i].name, pS[i].number);
? ? ? ? for (j = 0; j < m; j++)
? ? ? ? {
? ? ? ? ? ? strcpy(pS[i].pC[j].name, course[j]);
? ? ? ? ? ? scanf("%d", &pS[i].pC[j].score);
? ? ? ? }
? ? }
? ? return pS;
}
// 打印所有學(xué)生信息
void printStudentInfo(pStudent pS)
{
? ? int i, j;
? ? // 打印標(biāo)題
? ? printf("Name\tnumber\t");
? ? for (i = 0; i < m - 1; i++)
? ? ? ? printf("%s\t", course[i]);
? ? printf("%s\n", course[i]);
? ? // 顯示信息
? ? for (i = 0; i < n; i++)
? ? {
? ? ? ? printf("%s\t%s\t", pS[i].name, pS[i].number);
? ? ? ? for (j = 0; j < m - 1; j++)
? ? ? ? ? ? printf("%d\t", pS[i].pC[j].score);
? ? ? ? printf("%d\n", pS[i].pC[j].score);
? ? }
}file.c
#pragma once
#include "def.c"
Status saveStudentInfo(pStudent pS);
Status saveStudentInfo(pStudent pS)
{
? ? FILE *fp;
? ? int i, j;
? ? char filename[30], str[100] = "student number";
? ? printf("please input the filename: ");
? ? scanf("%s", filename);
? ? fp = fopen(filename, "w");
? ? if (!fp)
? ? ? ? return ERROR;
? ? for (i = 0; i < m; i++)
? ? {
? ? ? ? strcat(str, " ");
? ? ? ? strcat(str, course[i]);
? ? }
? ? strcat(str, "\n");
? ? for (i = 0; i < n; i++)
? ? {
? ? ? ? strcat(str, pS[i].name);
? ? ? ? strcat(str, " ");
? ? ? ? strcat(str, pS[i].number);
? ? ? ? for (j = 0; j < m; j++)
? ? ? ? {
? ? ? ? ? ? char score[30];
? ? ? ? ? ? itoa(pS[i].pC[j].score, score, 10);
? ? ? ? ? ? strcat(str, " ");
? ? ? ? ? ? strcat(str, score);
? ? ? ? }
? ? ? ? strcat(str, "\n");
? ? }
? ? fputs(str, fp);
? ? fclose(fp);
? ? return OK;
}menu.c
#pragma once
#include "def.c"
#include "myIO.c"
#include "file.c"
#include "function.c"
void menu();
void select();
// 菜單
void menu()
{
? ? printf("------------------------------------\n");
? ? printf("| ? ? ? ? ? ? ? ?Menu ? ? ? ? ? ? ?|\n");
? ? printf("| ? ? ? ? ? ? ?1. input ? ? ? ? ? ?|\n");
? ? printf("| ? ? ? ? ? ? ?2. show ? ? ? ? ? ? |\n");
? ? printf("| ? ? ? ? ? ? ?3. save ? ? ? ? ? ? |\n");
? ? printf("| ? ? ? ? ? ? ?4. sort ? ? ? ? ? ? |\n");
? ? printf("| ? ? ? ? ? ? ?5. modify ? ? ? ? ? |\n");
? ? printf("| ? ? ? ? ? ? ?6. count ? ? ? ? ? ?|\n");
? ? printf("| ? ? ? ? ? ? ?0. exit ? ? ? ? ? ? |\n");
? ? printf("------------------------------------\n");
}
void select()
{
? ? int branch;
? ? while (TRUE)
? ? {
? ? ? ? system("cls");
? ? ? ? menu();
? ? ? ? printf("[Input]: ");
? ? ? ? scanf("%d", &branch);
? ? ? ? if (!branch)
? ? ? ? ? ? break;
? ? ? ? switch (branch)
? ? ? ? {
? ? ? ? case 1:
? ? ? ? {
? ? ? ? ? ? pS = inputStudentInfo();
? ? ? ? ? ? if (pS == NULL)
? ? ? ? ? ? ? ? printf("input error! please input again\n");
? ? ? ? ? ? else
? ? ? ? ? ? ? ? printf("Input success!\n");
? ? ? ? ? ? system("pause");
? ? ? ? ? ? break;
? ? ? ? }
? ? ? ? case 2:
? ? ? ? {
? ? ? ? ? ? printStudentInfo(pS);
? ? ? ? ? ? system("pause");
? ? ? ? ? ? break;
? ? ? ? }
? ? ? ? case 3:
? ? ? ? {
? ? ? ? ? ? if (OK == saveStudentInfo(pS))
? ? ? ? ? ? ? ? printf("Save success!\n");
? ? ? ? ? ? else
? ? ? ? ? ? ? ? printf("Save fail!\n");
? ? ? ? ? ? system("pause");
? ? ? ? ? ? break;
? ? ? ? }
? ? ? ? case 4:
? ? ? ? {
? ? ? ? ? ? sort(pS);
? ? ? ? ? ? printf("sort success\n");
? ? ? ? ? ? system("pause");
? ? ? ? ? ? break;
? ? ? ? }
? ? ? ? case 5:
? ? ? ? {
? ? ? ? ? ? int res = modify(pS);
? ? ? ? ? ? if (res)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? printf("change success!\n");
? ? ? ? ? ? }
? ? ? ? ? ? else
? ? ? ? ? ? {
? ? ? ? ? ? ? ? printf("change fail!\n");
? ? ? ? ? ? }
? ? ? ? ? ? system("pause");
? ? ? ? ? ? break;
? ? ? ? }
? ? ? ? case 6:
? ? ? ? {
? ? ? ? ? ? int choose;
? ? ? ? ? ? // 輸入1 顯示每門課程最高成績(jī)信息
? ? ? ? ? ? // 輸入2 顯示每門課程平均成績(jī)信息
? ? ? ? ? ? printf("choose 1 for the highest score: \n ");
? ? ? ? ? ? printf("choose 2 for the average score: \n");
? ? ? ? ? ? printf("[Input]: ");
? ? ? ? ? ? scanf("%d", &choose);
? ? ? ? ? ? if (choose == 1)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? showMax(pS);
? ? ? ? ? ? }
? ? ? ? ? ? else if (choose == 2)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? showAverage(pS);
? ? ? ? ? ? }
? ? ? ? ? ? else
? ? ? ? ? ? {
? ? ? ? ? ? ? ? // 輸入非法提示信息
? ? ? ? ? ? ? ? printf("Input error!\n");
? ? ? ? ? ? }
? ? ? ? ? ? system("pause");
? ? ? ? ? ? break;
? ? ? ? }
? ? ? ? }
? ? }
}function.c
#include "def.c"
void sort(pStudent pS);
void Swap(pStudent s1, pStudent s2);
void showAverage(pStudent pS);
void showMax(pStudent pS);
Status modify(pStudent pS);
// 按課程成績(jī)排序
void sort(pStudent pS)
{
? ? int courseNumber, i, j, k;
? ? char courseName[30];
? ? printf("please input the course name which you want to sort: ");
? ? scanf("%s", courseName);
? ? for (courseNumber = 0; courseNumber < m; courseNumber++)
? ? ? ? if (strcmp(course[courseNumber], courseName) == 0)
? ? ? ? ? ? break;
? ? // 如果找不到課程,則認(rèn)為是按總分排序
? ? if (courseNumber == m)
? ? {
? ? ? ? printf("Sort as total score: \n");
? ? ? ? // 選擇排序
? ? ? ? for (i = 0; i < n - 1; i++)
? ? ? ? {
? ? ? ? ? ? int flag = i;
? ? ? ? ? ? for (j = i + 1; j < n; j++)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? int totalScore_1 = 0, totalScore_2 = 0;
? ? ? ? ? ? ? ? for (k = 0; k < m; k++)
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? totalScore_1 += pS[j].pC[k].score;
? ? ? ? ? ? ? ? ? ? totalScore_2 += pS[flag].pC[k].score;
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? if (totalScore_1 > totalScore_2)
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? flag = j;
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? ? ? Swap(&pS[i], &pS[flag]);
? ? ? ? }
? ? }
? ? else
? ? {
? ? ? ? // 選擇排序
? ? ? ? for (i = 0; i < n - 1; i++)
? ? ? ? {
? ? ? ? ? ? int flag = i;
? ? ? ? ? ? for (j = i + 1; j < n; j++)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? if (pS[j].pC[courseNumber].score > pS[flag].pC[courseNumber].score)
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? flag = j;
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? ? ? Swap(&pS[i], &pS[flag]);
? ? ? ? }
? ? }
}
// 修改學(xué)生信息
Status modify(pStudent pS)
{
? ? // 密碼是1314
? ? char password[30] = "1314", psd[30];
? ? char number[30];
? ? int score, i, j;
? ? printf("please input password: ");
? ? scanf("%s", psd);
? ? // 密碼正確才繼續(xù),否則返回ERROR
? ? if (strcmp(password, psd) == 0)
? ? {
? ? ? ? printf("please input the student's number: ");
? ? ? ? scanf("%s", number);
? ? ? ? for (i = 0; i < n; i++)
? ? ? ? {
? ? ? ? ? ? // 找到學(xué)生則繼續(xù),否則返回ERROR
? ? ? ? ? ? if (strcmp(pS[i].number, number) == 0)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? printf("please input the course and score one by one: \n");
? ? ? ? ? ? ? ? scanf("%s %d", courseName, &score);
? ? ? ? ? ? ? ? for (j = 0; j < m; j++)
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? // 找到課程才繼續(xù),否則返回ERROR
? ? ? ? ? ? ? ? ? ? if (strcmp(pS[i].pC[j].name, courseName) == 0)
? ? ? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? ? ? // 修改課程成績(jī)
? ? ? ? ? ? ? ? ? ? ? ? pS[i].pC[j].score = score;
? ? ? ? ? ? ? ? ? ? ? ? return OK;
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? return ERROR;
? ? ? ? ? ? }
? ? ? ? }
? ? ? ? return ERROR;
? ? }
? ? else
? ? ? ? return ERROR;
}
// 輸出各課程最高分的學(xué)生
void showMax(pStudent pS)
{
? ? int i, j, max;
? ? for (i = 0; i < m; i++)
? ? {
? ? ? ? max = 0;
? ? ? ? for (j = 0; j < n; j++)
? ? ? ? {
? ? ? ? ? ? if (pS[j].pC[i].score > pS[max].pC[i].score)
? ? ? ? ? ? ? ? max = j;
? ? ? ? }
? ? ? ? printf("%s\t%s\t%s\t%d\n", course[i], pS[max].name, pS[max].number, pS[max].pC[i].score);
? ? }
}
// 顯示各課程的平均成績(jī)
void showAverage(pStudent pS)
{
? ? int i, j;
? ? double ave;
? ? for (i = 0; i < m; i++)
? ? {
? ? ? ? ave = 0;
? ? ? ? for (j = 0; j < n; j++)
? ? ? ? {
? ? ? ? ? ? ave += pS[j].pC[i].score;
? ? ? ? }
? ? ? ? printf("%s\t%.2lf\n", course[i], ave / n);
? ? }
}
void Swap(pStudent s1, pStudent s2)
{
? ? int i;
? ? char studentName[30], number[30];
? ? // 交換姓名
? ? strcpy(studentName, s1->name);
? ? strcpy(s1->name, s2->name);
? ? strcpy(s2->name, studentName);
? ? // 交換學(xué)號(hào)
? ? strcpy(number, s1->number);
? ? strcpy(s1->number, s2->number);
? ? strcpy(s2->number, number);
? ? // 交換成績(jī)
? ? for (i = 0; i < m; i++)
? ? {
? ? ? ? int temp = s1->pC[i].score;
? ? ? ? s1->pC[i].score = s2->pC[i].score;
? ? ? ? s2->pC[i].score = temp;
? ? }
}以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- C語言編寫學(xué)生成績(jī)管理系統(tǒng)
- 學(xué)生成績(jī)管理系統(tǒng)C語言代碼實(shí)現(xiàn)
- C語言利用結(jié)構(gòu)體數(shù)組實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)
- C語言學(xué)生成績(jī)管理系統(tǒng)源代碼
- C語言實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)實(shí)戰(zhàn)教學(xué)
- C語言實(shí)現(xiàn)簡(jiǎn)單學(xué)生成績(jī)管理系統(tǒng)
- C語言結(jié)構(gòu)體版學(xué)生成績(jī)管理系統(tǒng)
- C語言實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)
- C語言學(xué)生成績(jī)管理系統(tǒng)課程設(shè)計(jì)
- C語言學(xué)生成績(jī)管理系統(tǒng)設(shè)計(jì)
相關(guān)文章
C++ 多線程編程建議之 C++ 對(duì)多線程/并發(fā)的支持(下)
這篇文章主要介紹的是 C++ 多線程編程建議之 C++ 對(duì)多線程/并發(fā)的支持的相關(guān)資料,承接前文 現(xiàn)代 C++ 對(duì)多線程/并發(fā)的支持,接下來我們看看回發(fā)生什么吧2021-10-10
C語言數(shù)據(jù)結(jié)構(gòu)的時(shí)間復(fù)雜度和空間復(fù)雜度
算法在編寫成可執(zhí)行程序后,運(yùn)行時(shí)需要耗費(fèi)時(shí)間資源和空間(內(nèi)存)資源 。因此衡量一個(gè)算法的好壞,一般是從時(shí)間和空間兩個(gè)維度來衡量的,即時(shí)間復(fù)雜度和空間復(fù)雜度,感興趣的同學(xué)可以參考閱讀2023-04-04
C++從匯編的視角審視對(duì)象的創(chuàng)建問題
這篇文章主要介紹了C++從匯編的視角看對(duì)象的創(chuàng)建,從匯編的視角來看,調(diào)用構(gòu)造器和調(diào)用 “返回對(duì)象” 的函數(shù)是一樣的,從匯編的角度來看,對(duì)象就是一堆數(shù)據(jù)的排列,比如說最普通的對(duì)象就是數(shù)據(jù)成員按照聲明順序直接排列,需要的朋友可以參考下2022-01-01
C++ Boost Serialization庫超詳細(xì)獎(jiǎng)金額
Boost是為C++語言標(biāo)準(zhǔn)庫提供擴(kuò)展的一些C++程序庫的總稱。Boost庫是一個(gè)可移植、提供源代碼的C++庫,作為標(biāo)準(zhǔn)庫的后備,是C++標(biāo)準(zhǔn)化進(jìn)程的開發(fā)引擎之一,是為C++語言標(biāo)準(zhǔn)庫提供擴(kuò)展的一些C++程序庫的總稱2022-12-12

