C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單學(xué)生成績(jī)管理系統(tǒng)
本文實(shí)例為大家分享了C語(yǔ)言實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)的具體代碼,供大家參考,具體內(nèi)容如下
C語(yǔ)言小項(xiàng)目
實(shí)現(xiàn)一個(gè)學(xué)生成績(jī)管理系統(tǒng)
系統(tǒng)功能:
1.實(shí)現(xiàn)所有學(xué)生成績(jī)的錄入(利用結(jié)構(gòu)體數(shù)組),當(dāng)輸入字符為end時(shí)候,結(jié)束成績(jī)的錄入;
2.實(shí)現(xiàn)所有學(xué)生信息的輸出
3.輸入指定學(xué)生姓名,并能輸出這名學(xué)生的信息
4.將學(xué)生成績(jī)按照語(yǔ)文和數(shù)學(xué)成績(jī)排序
思路:
1. 首先,先把這個(gè)小項(xiàng)目的框架打好??紤]要寫(xiě)幾個(gè)文件,每一個(gè)文件里面實(shí)現(xiàn)怎樣的功能。考慮到這個(gè)小項(xiàng)目的代碼量以及程序的易讀性,我決定將寫(xiě)三個(gè)文件。一個(gè)main.c,里面就寫(xiě)需要用到的函數(shù);一個(gè)teacher.c主要實(shí)現(xiàn)main.c函數(shù)里面具體的內(nèi)容;一個(gè)teacher.h里面主要寫(xiě)這個(gè)項(xiàng)目我們需要用到一些宏定義和函數(shù),以便在另外兩個(gè)C文件里面調(diào)用。(注意:在兩個(gè)C文件里面要包括teacher.h文件)。
2. 其次,分析一下這個(gè)系統(tǒng)要實(shí)現(xiàn)的功能,有四個(gè)功能。我們可以每一個(gè)功能寫(xiě)一個(gè)函數(shù),分別實(shí)現(xiàn)全部錄入,全部輸出,指定學(xué)生信息輸出以及語(yǔ)文和數(shù)學(xué)成績(jī)的排序這四個(gè)函數(shù)。將這四個(gè)函數(shù)的具體實(shí)現(xiàn)放在teacher.c文件里面。Main.c就負(fù)責(zé)直接調(diào)用這些函數(shù)。
3. 最后,考慮到需要錄入的時(shí)學(xué)生信息,包括姓名,學(xué)號(hào),性別,語(yǔ)文成績(jī),數(shù)學(xué)成績(jī)這些內(nèi)容。所以,考慮用結(jié)構(gòu)體數(shù)組來(lái)實(shí)現(xiàn)。
Teacher.h文件
#ifndef _TEACHER_H_
#define _TEACHER_H_
struct student
{
char name[20];
int id;
char sex;
int chinese;
int math;
};
typedef struct student stu;
void show_message(stu *st, int len);
int input(stu *st);
void find(stu *st, int len);
void sort(stu *st, int len);
void out(stu *st, int i);
void welcome();
void showchoice();
#endif
Main.c文件
#include <stdio.h>
#include <string.h>
#include "teacher.h"
#include <stdlib.h>
int main()
{
int len;
int m;
stu st[100];
welcome();
while(1)
{
showchoice();
scanf("%d", &m);
switch(m)
{
case 1: len = input(st);break;
case 2: show_message(st , len);break;
case 3: find(st , len);break;
case 4: sort(st , len);break;
default : exit(0);
}
}
return 0;
}
Teacher.c文件
#include <string.h>
#include <stdio.h>
#include "teacher.h"
void welcome() //系統(tǒng)界面歡迎函數(shù)
{
system("clear");
printf("*********************************\n");
printf("WELCOME TO TEACHER SYSTEM!\n");
printf("*********************************\n");
sleep(2);
}
void showchoice() //選擇提示函數(shù)
{
//system("clear");
printf("*********************************\n");
printf("1 input! 2 showinfor!\n");
printf("3 find! 4 sort!\n");
printf("*********************************\n");
printf("Please input your choice :\n");
}
void out(stu *st, int i) //輸出第i個(gè)學(xué)生的信息
{
printf("%s ",st[i].name);
printf("%d ",st[i].id);
printf("%c ",st[i].sex);
printf("%d ",st[i].chinese);
printf("%d",st[i].math);
printf("\n");
}
int input(stu *st) //錄入學(xué)生信息
{
int i;
printf("Input name, id, sex, Chinese score, Math score:\n");
for(i = 0; i < 100; i++)
{
scanf("%s", st[i].name);
if((!strcmp(st[i].name , "end")))
{
return i;
}
scanf("%d", &st[i].id);
scanf("%s", &st[i].sex);
scanf("%d", &st[i].chinese);
scanf("%d", &st[i].math);
}
return i;
}
void show_message(stu *st, int len) //輸出全部學(xué)生信息
{
int i;
printf("name, id, sex, Chinese score, Math score:\n");
for(i = 0; i < len; i++)
{
out(st, i);
}
}
void find(stu *st,int len) //查找出特定學(xué)生信息
{
char tmp[20];
int i;
printf("Please input the target student:\n");
scanf("%s", tmp);
for(i = 0; i < len; i++ )
{
if(!strcmp(st[i].name,tmp))
{
out(st, i);
}
}
}
void sort(stu *st, int len) //將數(shù)學(xué),語(yǔ)文成績(jī)冒泡排序
{
int tmp;
int i,j,k;
int id,sex,chinese,math;
char name[20];
int choice;
printf("\n");
printf("Please input your sort choice:\n"); //選擇提示:1 數(shù)學(xué)成績(jī)排序 2 語(yǔ)文成績(jī)排序
printf("1 math grade! 2 chinese grade!\n");
printf("\n");
scanf("%d",&choice);
if(1 == choice)
{
for(i = 0;i < len-1;i++)
{
for(j = 0;j < len-1-i;j++)
{
if(st[j].math > st[j+1].math) //將成績(jī)較大的學(xué)生信息放到成績(jī)較低的后面
{
tmp = st[j].math;
st[j].math = st[j+1].math;
st[j+1].math = tmp;
strcpy(name,st[j].name);
strcpy(st[j].name,st[j+1].name);
strcpy(st[j+1].name,name);
id = st[j].id;
st[j].id = st[j+1].id;
st[j+1].id = id;
sex = st[j].sex;
st[j].sex = st[j+1].sex;
st[j+1].sex = sex;
chinese = st[j].chinese;
st[j].chinese = st[j+1].chinese;
st[j+1].chinese = chinese;
}
}
}
printf("After sort math grade :\n");
for(k = 0;k < len;k++)
{
out(st, k);
}
}
else if(2 == choice)
{
for(i = 0;i < len-1;i++)
{
for(j = 0;j < len-1-i;j++)
{
if(st[j].chinese > st[j+1].chinese)
{
tmp = st[j].chinese;
st[j].chinese = st[j+1].chinese;
st[j+1].chinese = tmp;
math = st[j].math;
st[j].math = st[j+1].math;
st[j+1].math = math;
strcpy(name,st[j].name);
strcpy(st[j].name,st[j+1].name);
strcpy(st[j+1].name,name);
id = st[j].id;
st[j].id = st[j+1].id;
st[j+1].id = id;
sex = st[j].sex;
st[j].sex = st[j+1].sex;
st[j+1].sex = sex;
}
}
}
printf("After sort chinese grade :\n");
for(k = 0;k < len;k++)
{
out(st,k);
}
}
else
{
printf("Input error!\nPlease input again!\n");
}
}
小項(xiàng)目程序我自己測(cè)試過(guò),如果大家發(fā)現(xiàn)有不對(duì)的地方請(qǐng)多多指出。大家一起學(xué)習(xí),一起進(jìn)步!
更多學(xué)習(xí)資料請(qǐng)關(guān)注專(zhuān)題《管理系統(tǒng)開(kāi)發(fā)》。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- C語(yǔ)言編寫(xiě)學(xué)生成績(jī)管理系統(tǒng)
- 學(xué)生成績(jī)管理系統(tǒng)C語(yǔ)言代碼實(shí)現(xiàn)
- C語(yǔ)言利用結(jié)構(gòu)體數(shù)組實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)
- C語(yǔ)言學(xué)生成績(jī)管理系統(tǒng)源代碼
- C語(yǔ)言實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)實(shí)戰(zhàn)教學(xué)
- C語(yǔ)言結(jié)構(gòu)體版學(xué)生成績(jī)管理系統(tǒng)
- 使用C語(yǔ)言實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)
- C語(yǔ)言實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)
- C語(yǔ)言學(xué)生成績(jī)管理系統(tǒng)課程設(shè)計(jì)
- 基于C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單學(xué)生成績(jī)管理系統(tǒng)
相關(guān)文章
C++實(shí)現(xiàn)二叉樹(shù)的堂兄弟節(jié)點(diǎn)查詢
C++實(shí)現(xiàn)二叉樹(shù)的堂兄弟節(jié)點(diǎn)查詢,是指在二叉樹(shù)中,找到兩個(gè)節(jié)點(diǎn)深度相同但父節(jié)點(diǎn)不同的節(jié)點(diǎn),即為堂兄弟節(jié)點(diǎn)。實(shí)現(xiàn)這一功能可以通過(guò)遍歷二叉樹(shù)并記錄節(jié)點(diǎn)深度和父節(jié)點(diǎn)來(lái)實(shí)現(xiàn)2023-04-04
C++設(shè)計(jì)模式之簡(jiǎn)單工廠模式的實(shí)現(xiàn)示例
這篇文章主要給大家介紹了關(guān)于C++設(shè)計(jì)模式之簡(jiǎn)單工廠模式的相關(guān)資料,簡(jiǎn)單工廠模式,主要用于創(chuàng)建對(duì)象,添加類(lèi)時(shí),不會(huì)影響以前的系統(tǒng)代碼,需要的朋友可以參考下2021-06-06
C++中與輸入相關(guān)的istream類(lèi)成員函數(shù)簡(jiǎn)介
這篇文章主要介紹了C++中與輸入相關(guān)的istream類(lèi)成員函數(shù)簡(jiǎn)介,包括eof函數(shù)和peek函數(shù)以及putback函數(shù)還有ignore函數(shù),需要的朋友可以參考下2015-09-09
C++小利器之std::bind參數(shù)綁定包裝器的使用詳解
從 C++11 開(kāi)始,標(biāo)準(zhǔn)庫(kù)提供了 std::bind 用于綁定函數(shù) f 和調(diào)用參數(shù),返回一個(gè)新可調(diào)用函數(shù)對(duì)象 fn,下面就跟隨小編一起深入了解一下std::bind的具體使用吧2023-12-12
C++ std::condition_variable 條件變量用法解析
condition_variable(條件變量)是 C++11 中提供的一種多線程同步機(jī)制,它允許一個(gè)或多個(gè)線程等待另一個(gè)線程發(fā)出通知,以便能夠有效地進(jìn)行線程同步,這篇文章主要介紹了C++ std::condition_variable 條件變量用法,需要的朋友可以參考下2023-09-09
C++程序中使用Windows系統(tǒng)Native Wifi API的基本教程
這篇文章主要介紹了C++程序中使用Windows系統(tǒng)Native Wifi API的基本教程,包括在程序中控制無(wú)線網(wǎng)卡開(kāi)關(guān)的方法,需要的朋友可以參考下2016-03-03
C++使用數(shù)組來(lái)實(shí)現(xiàn)哈夫曼樹(shù)
給定N個(gè)權(quán)值作為N個(gè)葉子結(jié)點(diǎn),構(gòu)造一棵二叉樹(shù),若該樹(shù)的帶權(quán)路徑長(zhǎng)度達(dá)到最小,稱這樣的二叉樹(shù)為最優(yōu)二叉樹(shù),也稱為哈夫曼樹(shù)(Huffman?Tree)。哈夫曼樹(shù)是帶權(quán)路徑長(zhǎng)度最短的樹(shù),權(quán)值較大的結(jié)點(diǎn)離根較近2022-05-05

