学生信息管理系统-书本实例

2024-02-27 03:32

本文主要是介绍学生信息管理系统-书本实例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

写在前面

本例是南邮本科教材<<面向对象程序设计及C++(第2版)>>(就是下面这本,朱立华、俞琼、郭剑、朱建主编)中第六章后面的小 Project,简单的学生信息管理系统,没有 String、没有 vector,简单的类实现以及运算符重载操作。代码并不难,只是作为热身练习,不过修复 Bug 倒也耗费了不少时间。这里只做记录,mark 自己水过来的本科课程,以及现在重新回来填坑。

<<面向对象程序设计及C++(第2版)>>-朱立华、俞琼、郭剑、朱建主编

这里基本是重现了课本上的代码,顺带解决一些Visual Studio 2015下旧代码出现的问题,以及一些书本不小心的错误。

程序代码

程序代码包括 5 个源码文件:Student.hStudent.cppInterface.hInterface.cppMain.cpp。Student 类对应学生类,Interface 对应界面和一些对学生类的操作:浏览、查询、新增等操作,Main 函数启动程序。

代码中的输出操作本人为了保持与项目代码风格一致,刻意使用了 std::cout、std::endl 这种风格,没有使用命名空间。

Student.h

#ifndef STUDENT_H_
#define STUDENT_H_#include <iostream>
#include <fstream>
#include <string.h>class Person
{
protected:char *name;char sex;int age;
public:Person();Person(char *na,char s,int a);~Person();};class Student:virtual public Person
{
protected:char speciality[20];char number[16];
public:Student();Student(char *na,char s,int a,char *spec,char *num);~Student();Student & operator = (Student &);operator char *();operator char();operator int();friend std::ostream & operator <<(std::ostream &, const Student &);friend std::istream & operator >>(std::istream &, Student &);};#endif // !STUDENT_H_

Student.cpp

#include "Student.h"Person::Person()
{name = NULL;
}Person::Person(char * na, char s, int a)
{if (na){name = new char[strlen(na) + 1];strcpy_s(name,strlen(na)+1,na);}sex = s;age = a;
}Person::~Person()
{if (name){delete[]name;}
}Student::Student()
{
}Student::Student(char * na, char s, int a, char * spec, char *num): Person(na,s,a)
{strcpy_s(speciality, strlen(spec) + 1, spec);strcpy_s(number, strlen(num) + 1, num);
}Student::~Student()
{}Student & Student::operator=(Student &st)
{// TODO: ÔÚ´Ë´¦²åÈë return Óï¾äif (name){delete []name;}if (st.name){name = new char[strlen(st.name) + 1];strcpy_s(name, strlen(st.name) + 1, st.name);}else{name = 0;}sex = st.sex;age = st.age;strcpy_s(speciality, strlen(st.speciality) + 1, st.speciality);strcpy_s(number, strlen(st.number) + 1, st.number);return *this;
}Student::operator char * ()
{return name;
}Student::operator char ()
{return sex;
}Student::operator int ()
{return age;
}std::ostream & operator<<(std::ostream & out, const Student & stu)
{// TODO: ÔÚ´Ë´¦²åÈë return Óï¾äout << stu.name << '\t';out << stu.sex << '\t';out << stu.age << '\t';out << stu.speciality << "\t\t";out << stu.number << '\n';return out;
}std::istream & operator >> (std::istream & in, Student & stu)
{// TODO: ÔÚ´Ë´¦²åÈë return Óï¾ächar temp[80];std::cout << "Please enter a student infomation:\n";std::cout << "Name: ";              in >> temp;if (temp){stu.name = new char[strlen(temp) + 1];strcpy_s(stu.name, strlen(temp) + 1, temp);}std::cout << "Sex: ";               in >> stu.sex;std::cout << "Age: ";               in >> stu.age;std::cout << "Speciality: ";        in >> stu.speciality;std::cout << "Student Number: ";    in >> stu.number;return in;
}

Interface.h

#ifndef INTERFACE_H_
#define INTERFACE_H_#include "Student.h"// student number
const int N = 2;class Interface
{
protected:Student stu[N];int num;
public:Interface();void Browse();void Run();void Input();void Sort();void Statistic();bool Search();
};#endif // !INTERFACE_H_

Interface.cpp

#include "Interface.h"
#include <string.h>
#include <iostream>Interface::Interface()
{num = 0;
}void Display() 
{std::cout << std::endl;std::cout << "**********0. EXIT\t**********" << std::endl;std::cout << "**********1. Input info\t**********" << std::endl;std::cout << "**********2. Search\t**********" << std::endl;std::cout << "**********3. Browse\t**********" << std::endl;std::cout << "**********4. Sort by age**********" << std::endl;std::cout << "**********5. Statistic\t**********" << std::endl;
}void Interface::Run()
{unsigned int choice;do{Display();std::cout << "Please choose:";std::cin >> choice;if (choice<0||choice>5){std::cout << "the num you choose must 0~5" << std::endl;return;}switch (choice){case 0:break;case 1:Input();break;case 2:Search();break;case 3:Browse();break;case 4:Sort();break;case 5:Statistic();break;default:break;}} while (choice);
}void Interface::Input()
{if (num == N) {std::cout << "\nInfomation was FULL !\n";return;}int i = num;std::cin >> stu[i];num++;
}void Interface::Browse()
{std::cout << "\n Information about Students that you would like to check£º\n";if (num == 0){std::cout << "\n No information !\n";return;}else{std::cout << "Name" << "\t" << "Sex" << "\t" << "Age" << "\t" << "Speciality" << "\t" << "SNumber" << "\n";for (int i = 0; i < num; i++){std::cout << stu[i];}}
}void Interface::Sort()
{std::cout << "\nSorted by age!\n";int k = 0;for (int i = 0; i < num - 1; i++){k = i;for (int j  = i+1; j < num; j++){if ((int)(stu[k]) > (int)(stu[j]))k = j;}if (k!=i){// Student t=stu[k]; doesnot call for operator =Student t;t = stu[k];stu[k] = stu[i];stu[i] = t;}}
}void Interface::Statistic()
{int m = 0;std::cout << "\nStatistic by stu sex!\n";for (int i = 0; i < num; i++){if (char(stu[i]) == 'M' || char(stu[i]) == 'm')m++;}std::cout << "\nResult! Male sut num:"<<m<<"!\n";
}bool Interface::Search()
{char na[20];std::cout << "\nThe stu name you want to locate:\n";std::cin >> na;int i = 0;for ( ; i < num; i++){if (strcmp((char*)(stu[i]), na) == 0)break;}if (i == num){std::cout << "\nNobody!\n";return false;}else{std::cout << stu[i];}return true;
}

Main.cpp

#include "Interface.h"int main() 
{Interface interface1;interface1.Run();return 0;
}

这篇关于学生信息管理系统-书本实例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

C++操作符重载实例(独立函数)

C++操作符重载实例,我们把坐标值CVector的加法进行重载,计算c3=c1+c2时,也就是计算x3=x1+x2,y3=y1+y2,今天我们以独立函数的方式重载操作符+(加号),以下是C++代码: c1802.cpp源代码: D:\YcjWork\CppTour>vim c1802.cpp #include <iostream>using namespace std;/*** 以独立函数

实例:如何统计当前主机的连接状态和连接数

统计当前主机的连接状态和连接数 在 Linux 中,可使用 ss 命令来查看主机的网络连接状态。以下是统计当前主机连接状态和连接主机数量的具体操作。 1. 统计当前主机的连接状态 使用 ss 命令结合 grep、cut、sort 和 uniq 命令来统计当前主机的 TCP 连接状态。 ss -nta | grep -v '^State' | cut -d " " -f 1 | sort |

Java Websocket实例【服务端与客户端实现全双工通讯】

Java Websocket实例【服务端与客户端实现全双工通讯】 现很多网站为了实现即时通讯,所用的技术都是轮询(polling)。轮询是在特定的的时间间隔(如每1秒),由浏览器对服务器发 出HTTP request,然后由服务器返回最新的数据给客服端的浏览器。这种传统的HTTP request 的模式带来很明显的缺点 – 浏 览器需要不断的向服务器发出请求,然而HTTP

828华为云征文|华为云Flexus X实例docker部署rancher并构建k8s集群

828华为云征文|华为云Flexus X实例docker部署rancher并构建k8s集群 华为云最近正在举办828 B2B企业节,Flexus X实例的促销力度非常大,特别适合那些对算力性能有高要求的小伙伴。如果你有自建MySQL、Redis、Nginx等服务的需求,一定不要错过这个机会。赶紧去看看吧! 什么是华为云Flexus X实例 华为云Flexus X实例云服务是新一代开箱即用、体

华为OD机试真题-学生方阵-2024年OD统一考试(E卷)

题目描述 学校组织活动,将学生排成一个矩形方阵。 请在矩形方阵中找到最大的位置相连的男生数量。这个相连位置在一个直线上,方向可以是水平的,垂直的,成对角线的或者呈反对角线的。 注:学生个数不会超过10000 输入描述 输入的第一行为矩阵的行数和列数, 接下来的 n行为矩阵元素,元素间用""分隔。 输出描述 输出一个整数,表示矩阵中最长的位

LLVM入门2:如何基于自己的代码生成IR-LLVM IR code generation实例介绍

概述 本节将通过一个简单的例子来介绍如何生成llvm IR,以Kaleidoscope IR中的例子为例,我们基于LLVM接口构建一个简单的编译器,实现简单的语句解析并转化为LLVM IR,生成对应的LLVM IR部分,代码如下,文件名为toy.cpp,先给出代码,后面会详细介绍每一步分代码: #include "llvm/ADT/APFloat.h"#include "llvm/ADT/S

OpenStack离线Train版安装系列—11.5实例使用-Cinder存储服务组件

本系列文章包含从OpenStack离线源制作到完成OpenStack安装的全部过程。 在本系列教程中使用的OpenStack的安装版本为第20个版本Train(简称T版本),2020年5月13日,OpenStack社区发布了第21个版本Ussuri(简称U版本)。 OpenStack部署系列文章 OpenStack Victoria版 安装部署系列教程 OpenStack Ussuri版

OpenStack实例操作选项解释:启动和停止instance实例

关于启动和停止OpenStack实例 如果你想要启动和停止OpenStack实例时,有四种方法可以考虑。 管理员可以暂停、挂起、搁置、停止OpenStack 的计算实例。但是这些方法之间有什么不同之处? 目录 关于启动和停止OpenStack实例1.暂停和取消暂停实例2.挂起和恢复实例3.搁置(废弃)实例和取消废弃实例4.停止(删除)实例 1.暂停和取消暂停实例

Cmake之3.0版本重要特性及用法实例(十三)

简介: CSDN博客专家、《Android系统多媒体进阶实战》一书作者 新书发布:《Android系统多媒体进阶实战》🚀 优质专栏: Audio工程师进阶系列【原创干货持续更新中……】🚀 优质专栏: 多媒体系统工程师系列【原创干货持续更新中……】🚀 优质视频课程:AAOS车载系统+AOSP14系统攻城狮入门视频实战课 🚀 人生格言: 人生从来没有捷径,只有行动才是治疗恐惧