第二节 学生系统管理讨论与修改 150206118

通过学习学生信息管理系统软件,我了解到了基于函数的结构化大型程序的编写方法;了解到C语言管理软件的设计方法和编程思路。大概知道了编写的流程、要点还有一些基本命令。

首先,要明确编写的题目,也就是编写的内容主题。然后根据主题将现实中的要用到的东西抽象化(就是将一些实际的东西定义一下,写进程序里)。接着,就开始构建一个整体的框架,内容的具体功能划分,功能之间的联系等。例如学生信息管理系统中,需要同时保存一个学生的姓名,性别,年龄等信息。

而这些需要录入的信息都是归于一个学生之下的资料,所以学生又是一个构架,用学号来管理。

定义一种形式,一个变量同时记录很多的信息,这样在管理系统中,就方便很多了。这就是结构体。

接下来便是具体化结构体和函数,也就是说完善功能,开始具体地编写各个功能的内容,实现功能,联系每个关联内容。

依然用学生系统软件为例:把同学按照专业分到不用的班级中,这样管理起来就方便多了,系里发通知等,只发到班长就行了,由班长向下传达,班级内部更改活动内容,也跟其他班级没有关系,自己关起门来修改就可以了。所以程序也是这样,如果是把所有的代码都放到一起,那跟全校所有的同学都在一个班级一样,互相之间相互联系,程序代码短还没有什么问题,程序代码量一多了,将非常难管理。所以按照功能,将不同的代码放到一起,用大括号括起来,然后给这段代码起个名字表示,类似咱们班级的名字,然后还要设置上参数,一遍使用这个函数的时候向里传递实际的值,类似一个加法的函数,完成两个数的相加,我们可以写成

myadd(int a, int b)

{

intc;

c=a+b;

returnc;

}

myadd就是我们给这个函数起的名字,以便使用,a和b的作用接收调用者传递过来的数,然后把接收的两个数相加后返回,这个函数的值在调用后就是返回的值c,所以如果我们想算99+23等于多少,只要调用我们写好的函数

myadd(99,23),这个时候函数的值就是99+23了,如果把结果保存在变量d中,可以写成

d=myadd(99,23);

有了函数,我们就可以把不同功能的代码组织到一起,不仅自己方便,而且程序特别简单明了,便于修改,其他人写的函数我们还可以直接拿来用。

所以我们的这个学生信息管理系统形式就非常简单了,一共用到了三个函数

int main()

{

inti,sum;

pagedis();

check();

menu();

}

第一个是显示欢迎页面,第二个是验证用户名和口令,第三个是显示菜单,并根据用户的输入选择执行相应的操作。

还有一些其他的函数,分别是menu()菜单函数调用的子函数。

结构话程序后大概的形式就是这样

#include<stdio.h>

void pagedis();

void check();

void menu();

int main()

{

pagedis();

check();

menu();

}

void pagedis(){

printf("我是显示欢迎界面的模块,具体内容还要再完善! \n");

}

void check(){

printf("我是验证用户合法性的模块,具体内容还要再完善! \n");

}

void menu(){

printf("我是引导用户执行各个功能的模块,具体内容还要再完善! \n");

}

这就是结构化程序设计,把功能放到函数中,下一步就可以集中精力,完善函数中的内容。

根据以上的思路,我将学生管理系统改成了饭店业绩管理系统。

代码如下:

/*

*饭店业绩管理程序,

*管理学生的个人信息及各科成绩;

*/

#include <stdio.h>

#include <conio.h>

#include <string.h>  【此处都是引用头文件】

#include <stdlib.h>

typedef struct Node Node;  【这里开始给我感觉就是构建结构体开始】

//定义成绩信息节点

//分别为菜品业绩(语文)、酒水业绩(数学)、开支(英语)和总业绩;

struct Score

{

int chinese,math,english,sum;  【分数,为了不影响系统,变量名称不改】

};

//定义学生信息节点

//分别为分店名称(姓名)、月业绩(班级)、具体日期(学号)、成绩和指向下一个节点的指针

//定义了4个全局变量节点,和临时节点变量;

struct Node

{

char name[20],classs[20],number[20]; 【个人信息】

struct Score score;

struct Node* next;

}*head,*u,*p,*q;

//定义多个学生的学生个数及各科平均成绩优秀率及格率;

int n,C,M,E,Cj,Cy,Mj,My,Ej,Ey;

char num[20];

【到这里都是结构体的构建,值得注意的是分开了个人、班级还有全局的构建,方便查看】

//进入菜单函数

void Welcome()

{

printf("\t\t      # # # # # ## # # # # # # # # # #\n");

printf("\t\t      #   欢迎您使用饭店业绩管理系统#\n");

printf("\t\t      #                              #\n");

printf("\t\t      #         1.读取文件           #\n");

printf("\t\t      #                              #\n");

printf("\t\t      #         2.保存文件           #\n");

printf("\t\t      #                              #\n");

printf("\t\t      #         3.添加饭店业绩       #\n");

printf("\t\t      #                              #\n");

printf("\t\t      #         4.修改饭店业绩       #\n");

printf("\t\t      #                              #\n");

printf("\t\t      #         5.删除饭店业绩       #\n");

printf("\t\t      #                              #\n");

printf("\t\t      #         6.查询具体分店       #\n");

printf("\t\t      #                              #\n");

printf("\t\t      #         7.查询指定月份       #\n");

printf("\t\t      #                              #\n");

printf("\t\t      #         8.查询所有业绩       #\n");

printf("\t\t      #                              #\n");

printf("\t\t      #         9.退出管理系统       #\n");

printf("\t\t      #                              #\n");

printf("\t\t      # # # # # ## # # # # # # # # # #\n\n");

printf("\t\t       请输入指令:(1-9)");

}

//构造节点函数【用了指针,然而具体功能不太清楚】

【估计是设置一个新的指针指向某个目标】

Node* new_node(Node* uu)

{

uu = (Node*)malloc(sizeof(Node));

uu->next = NULL;

return uu;

}

//添加学生信息

void Add()

{

//新建一个节点;【开始学生信息函数建立,我改成了饭店】

u= new_node(u);  //【用到了指针】

printf("\n请输入您要加入的业绩的信息:\n");

printf("\n饭店名称: ");

scanf("%s",u->name);

printf("\n月份: ");

scanf("%s",u->classs);

printf("\n具体日月: ");

scanf("%s",u->number);

printf("\n菜品业绩、酒水业绩、开支:");

scanf("%d%d%d",&u->score.chinese,&u->score.math,&u->score.english);

//计算总成绩;

u->score.sum = u->score.chinese + u->score.math -u->score.english;  【我改变了算法】

//采用头插法将新节点的尾指针指向第二个节点(掰开)【用了指针,大概是返回的功能】

u->next = head->next;

//将新节点放在头节点后面;

head->next = u;

printf("\n--->添加成功!\n");

}

//根据学号修改信息【第二个函数,用了指针来搜,对比,实现查询然后修改】

//和查找函数一样,依次从第二个节点开始遍历,如果找到这更新

void Mod()

{

n= 0;

printf("\n请输入您要修改的具体日期(如0212): ");

scanf("%s",num);

for(u = head; u != NULL;u = u->next)

{

if(strcmp(u->number,num) == 0)

{

n = 1;

printf("\n请输入新的菜品业绩、酒水业绩、开支: ");

scanf("%d%d%d",&u->score.chinese,&u->score.math,&u->score.english);

u->score.sum = u->score.chinese + u->score.math +u->score.english;

printf("\n--->修改成功!\n");

break;

}

}

if(!n)

printf("\n--->没有这个日期信息!\n");

}

//根据学号删除学生信息,【第三个函数】

//从头节点开始遍历,如果找到这删除此节点;

void Del()

{

n= 0;

printf("\n请输入您要删除业绩的日期: ");

scanf("%s",num);

for(u = head; u != NULL;u = u->next)

{

if(strcmp(u->number,num) == 0) //【实现删除】

{

n = 1;

p->next = u->next;

free(u);

printf("\n--->删除成功!\n");

break;

}

p = u;

}

if(!n)

printf("\n--->没有这个日期信息!\n");

}

void Sort()

{

int i,j;

//记录学生总数;【第四个】

n= 0;

for(u = head->next; u != NULL;u = u->next)

n++;

//采用冒泡法对各个节点按班级升序和总成绩降序排列【冒泡什么的没学,感觉大概就是排序】

for(i=1;i<=n;i++)

{

u = head;

for(j=0;j<n-i;j++)

{

p = u->next;

q = p->next;

if(strcmp(p->classs,q->classs) > 0 ||strcmp(p->classs,q->classs) == 0 && p->score.sum <q->score.sum)

{

u->next = q;

p->next = q->next;

q->next = p;

}

u = u->next;

}

}

}

//按学号查找某一学生成绩;【第五个】

void Que_One()

{

//标志变量,记录是否查找成功;

n= 0;

printf("\n请输入您要查询的具体日期: ");

scanf("%s",num);

//从第二个节点开始遍历,直到最后一个节点为止;【也是用指针对比搜索】

for(u = head->next; u != NULL;u = u->next)

{

//如果当前节点学号与要查找学号一致这输出此学生信息;

if(strcmp(u->number,num) == 0)

{

n = 1;

printf("\n");

puts("月业绩       分店名称       菜品业绩  酒水业绩  支出 总营业业绩");

printf("%-11s%-15s",u->classs,u->name);

printf("%-6d%-6d%-6d%-6d\n",u->score.chinese,u->score.math,u->score.english,u->score.sum);

break;

}

}

if(!n)

printf("\n--->没有这个学生的信息!\n");

}

void Analyze_Sco(Node *uu)  【第六个】

{

//对查找到的节点进行求各科平均成绩

//求优秀率及格率;

C+= uu->score.chinese;

M+= uu->score.math;

E+= uu->score.english;

if(uu->score.chinese >= 60)

Cj++;

if(uu->score.chinese >= 90)

Cy++;

if(uu->score.math >= 60)

Mj++;

if(uu->score.math >= 90)

My++;

if(uu->score.english >= 60)

Ej++;

if(uu->score.english >= 90)

Ey++;

}

//打印各科平均成绩及格率优秀率

void Print_Sco() 【第七个打印平均的】

{

printf("菜品业绩平均: %-6.2f\n\n",(float)C/n);

printf("酒水业绩平均: %-6.2f\n\n",(float)M/n);

printf("支出平均: %-6.2f\n\n",(float)E/n);

}

//查找某一班级所以学生的信息;

void Que_Cla() 【第八个】

{

//对链表节点排序;【下列一串大概就是链表】

Sort();

n= C = M = E = Cj = Cy = Mj = My = Ej = Ey = 0;

printf("\n请输入您要查询的月份: ");

scanf("%s",num);

printf("\n");

for(u = head->next; u != NULL;u = u->next)

{

//不是该班的学生则跳过;【对比跳过】

if(strcmp(u->classs,num))

continue;

//如果是第一个学生则打印头信息

if(!n)

puts("具体日期       分店名称       菜品业绩  酒水业绩  开支 总业绩");

n++;

printf("%-11s%-15s",u->number,u->name);

printf("%-6d%-6d%-6d%-d\n",u->score.chinese,u->score.math,u->score.english,u->score.sum);

Analyze_Sco(u);

}

if(!n)

{

printf("没有这个班级的学生信息!\n");

return ;

}

//打印该班级学生的各个成绩的特征值;

printf("\n该月共有 %d 单.\n\n",n);

Print_Sco();

}

//打印全校所以学生的信息

//具体情况同打印班级学生信息;【第九个,全部的信息】

void Que_All()

{

Sort();

n= C = M = E = Cj = Cy = Mj = My = Ej = Ey = 0;

printf("\n");

if(head->next == NULL)

{

printf("--->没有信息!\n");

return ;

}

puts("月份        具体日期     分店名称       菜品业绩  酒水业绩  开支 总业绩");

for(u = head->next; u != NULL;u = u->next)

{

n++;

printf("%-12s%-12s%-15s",u->classs,u->number,u->name);

printf("%-6d%-6d%-6d%-d\n",u->score.chinese,u->score.math,u->score.english,u->score.sum);

Analyze_Sco(u);

}

printf("\n全部共有 %d 单.\n\n",n);

Print_Sco();

}

//保存文件;

void Save() 【第十个,文件保存函数】

{

char c;

printf("\n确认保存?(Y/N): ");

scanf("%*c%c",&c);

if(c == ‘N‘)

return ;

FILE *fp;

if((fp=fopen("C:\\data.txt","w"))==NULL)

{

printf("\n--->无法打开文件\n");

return ;

}

//写入数据表头信息;

fputs("月份       具体日期    分店名称     菜品业绩  酒水业绩  开支 总业绩",fp);

if(head->next != NULL)

fputs("\n",fp);

//从头节点开始依次写入文件;

for(u = head->next; u != NULL;u = u->next)

{

fprintf(fp,"%-11s%-11s%-15s",u->classs,u->number,u->name);

fprintf(fp,"%-6d%-6d%-6d%-d",u->score.chinese,u->score.math,u->score.english,u->score.sum);

if(u->next != NULL)

fprintf(fp,"\n");

}

fclose(fp);

printf("\n--->成绩成功存入C:\\\\data.txt中\n");

}

//读取文件;【第十一个,文件打开函数】

void Open()

{

printf("\n请把数据放到目录C:\\\\data.txt中,按任意键确认.\n");

getch();

FILE *fp;

//从c盘根目录下读取文件;

if((fp=fopen("C:\\data.txt","r"))==NULL)

{

printf("\n--->没有找到文件!\n");

return ;

}

char tmp[100];

//读取65个菜单头字符存入tem字符数组中;

fgets(tmp,66,fp);

//读到文件结尾处跳出循环;

while(!feof(fp))

{

u = new_node(u);

fscanf(fp,"%s%s%s",u->classs,u->number,u->name);

fscanf(fp,"%d%d%d%d",&u->score.chinese,&u->score.math,&u->score.english,&u->score.sum);

//头插法建立链表;

u->next = head->next;

head->next = u;

}

printf("\n--->成绩读入成功!\n");

fclose(fp);

}

//退出程序

void Exi()

{

char c;

printf("\n确定退出?(Y/N):");

scanf("%*c%c",&c);

if(c == ‘N‘)

return ;

//打印结束语;

system("cls");

printf("\n\n");

printf("\t\t\t     %c %c %c%c %c %c %c %c %c\n",4,4,4,4,4,4,4,4,4);

printf("\t\t\t     %c 谢谢使用%c\n",4,4);

printf("\t\t\t     %c %c %c%c %c %c %c %c %c\n",4,4,4,4,4,4,4,4,4);

printf("\t\t\t                          Thankyou!\n\n\n");

exit(0);

}

int main() //【这里才是主函数,执行啦!】

{

//存储指令的变量

int orz;

//设置系统文本颜色

system("color 0B");

//新建一个学生信息头节点;

head = new_node(head);

while(1)

{

//显示菜单、

Welcome();

//接收用户命令、

scanf("%d",&orz);

//调用系统函数清屏;

system("cls");

switch(orz)

{

//根据指令进入相应菜单选项

case 1:Open();break;

case 2:Save();break;

case 3:Add();break;

case 4:Mod();break;

case 5:Del();break;

case 6:Que_One();break;

case 7:Que_Cla();break;

case 8:Que_All();break;

case 9:Exi();break;

default :printf("\n--->无效的指令!\n");

}

printf("\n");

//执行系统函数

system("pause");

system("cls");

}

return 0;

}

时间: 2024-10-08 10:44:16

第二节 学生系统管理讨论与修改 150206118的相关文章

【软件构造】第三章第二节 设计规约

第三章第二节 软件规约 这一节我们转向关注"方法/函数/操作"是如何定义的,即讨论编程中的动词,规约. Outline 一个完整的方法 什么是设计规约,我们为什么需要他 行为等价性 规约的结构:前置条件与后置条件 规约的结构 可变方法的规约 规约的评价 规约的确定性 规约的陈述性 规约的强度 如何设计一个好的规约 是否使用前置条件 Notes ## 一个完整的方法 一个完整的方法包括规约spec和实现体implementation: "方法"是程序的积木,它可以被独

杨森翔:春节文化大观上编 第三章 春节古诗词 目录 第一节:春节诗词概述 一、 除夕诗词概述 二、元日诗词概述 三、 元宵诗词概述 第二节:春节古诗词拾萃

杨森翔:春节文化大观上编 第三章 春节古诗词 目录 第一节:春节诗词概述 一. 除夕诗词概述 二.元日诗词概述 三. 元宵诗词概述 第二节:春节古诗词拾萃 一.腊祭诗词 二.祭灶诗词 三.除夕诗词 四.元旦诗词 五.人日诗词 六.元宵诗词 第一节:春节古诗词概述 中国的春节,作为除旧迎新的节日,时间相当长,从年前的腊月二十三,天空中就似乎弥漫了节日的气息.这种节日的气氛,在保持传统风俗较好的地方,甚至会持续到二月二龙抬头的时候,但欢度春节的高潮,应该说是自除夕始一直到上元之夜.因此,历代歌咏和反

OC第二节的总结

实例变量的可见度:@public:公共的,在任何文件中都可以访问,(访问方式是对象+指向操作符+实例变量,例如:per->name)@protected:受保护的,有一定的访问权限,只允许在本类文件以及子类文件中访问,其他文件不可以访问@private:私有的,只允许在本类文件中访问,不可以在子类文件 以及其他文件中访问默认的可见度是@protected为什么不声明为@public?   1.声明为@public的实例变量,外部就可以访问以及修改,会影响内部的一个实现,暴露实现细节   2.违背

辛星跟您玩转vim第二节之用vim命令移动光标

首先值得一提的是,我的vim教程pdf版本已经写完了,大家可以去下载,这里是csdn的下载地址:csdn下载,如果左边的下载地址挂掉了,也可以自行在浏览器下面输入如下地址进行下载:http://download.csdn.net/detail/xinguimeng/7714213 ,当然,如果你是百度网盘的忠实用户,也可以借助于百度网盘,我也同步上传到百度网盘了,下载地址如下:百度网盘下载 ,如果地址挂了,可以在浏览器中输入:http://pan.baidu.com/s/1sj9CLXz 来下载

【读书笔记】《鸟哥Linux私房菜-基础知识篇》第二节 基础命令

第二节 基础命令 uname –r 查询Linux核心版本. 装置及装置在Linux内的文件名 IDE硬盘机 /dev/hd[a-d] SCSI/SATA/USB硬盘机 /dev/sd[a-p] USB快闪碟 /dev/sd[a-p] 软盘驱动器 /dev/fd[0-1] 打印机 25针:/dev/lp[0-2] USB:/dev/usb/lp[0-15] 鼠标 USB:/dev/usb/mouse[0-15] PS2:/dev/psaux 当前CDROM/DVDROM /dev/cdrom 当

Citrix XenApp&XenDesktop 7.15 部署实践指南——第二节·环境介绍

参考之前的的XenServer或vSphere手册配置Hypervisor,并完成虚拟机操作系统模板的创建,然后按照下表创建虚拟机,修改计算机名,配置IP地址,加域:具体创建过程不再此手册中体现:XenServer部分相关内容参考itdali.cn . 所有Windows.Windows Server都强烈建议更新至最新的补丁,这样可避免在Citrix环境下很多问题的发生:所有Windows.Windows Server在制作模板时也都建议安装.net framework 3.5..net fr

【软件构造】第六章第二节 可维护的设计模式

第六章第二节 可维护的设计模式 Outline 创造性模式:Creational patterns 工厂模式(Factory Pattern) 抽象工厂模式(Abstract Factory Pattern) 建造者模式(Builder Pattern) 结构化模式:Structural patterns 桥接模式(Bridge Pattern) 代理模式(Proxy Pattern) 组合模式(Composite Pattern) 行为化模式:Behavioral patterns 中介者模式

centos单用户 救援 运行级别 第二节课

centos单用户 救援 运行级别 第二节课 yum工具在minimal安装级别就已经安装 yum list:列出远程服务器端的所有的包的列表 安装桌面套件,安装图形化桌面 yum groupinstall -y "desktop"yum groupinstall -y "X window system" 临时显示英文 LANG=en

第二节 分支结构

在程序开发中,分支结构的使用频率要多于循环结构,10次分支,4次循环. 程序开发三种情况:分支,循环,分支 (1) if的三种格式: int a = 10; if(a > o) { printf("%d",a) } 当条件表达式的条件成立时,或为真时,执行大括号内的语句,否则执行if之后的语句. (2) char sex = 0; printf("请输入你的性别:m或者f"); scanf("%c",&sex); if(sex ==