广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C++实现教师管理系统
  • 108
分享到

C++实现教师管理系统

2024-04-02 19:04:59 108人浏览 安东尼
摘要

本文实例为大家分享了c++实现教师管理系统的具体代码,供大家参考,具体内容如下 链表模板定义:就是用这种数据类型来进行存储 #include<iOStream> #if

本文实例为大家分享了c++实现教师管理系统的具体代码,供大家参考,具体内容如下

链表模板定义:就是用这种数据类型来进行存储

#include<iOStream>
#ifndef nodeLIST_S
#define NODELIST_S

template<typename T>
class Node
{
public:
    T s_Data;
    Node<T>* s_Next;

    Node(const T&data) :s_Data(data), s_Next(nullptr){}
};

template<typename T>
class NodeList
{
private:
    Node<T>* s_Head;
    int s_Number;

public:
    NodeList() : s_Head(nullptr), s_Number(0){}
    ~NodeList() { Clear(); }
    Node<T>*GetHead() { return s_Head; }
    int GetNum() { return s_Number; }
    bool Clear()
    {
        Node<T>*p = s_Head;
        for (int i = 0; i < s_Number; i++)
        {
            if (!p)return false;
            Node<T>*q = p;
            p = p->s_Next;
            delete q;
        }
        s_Head = nullptr;
        s_Number = 0;
        return true;
    }
    bool IsEmpty()
    {
        return (s_Number == 0);
    }
    bool AddAt(const T&, int i);//添加元素到第i个位置,计数从0开始
    bool RemoveAt(int i);//删除第i个元素
};

template<typename T>
bool NodeList<T>::AddAt(const T& data, int i)
{
    Node<T>* OneNode = new Node<T>(data);

    Node<T>* p;
    if (OneNode)
    {
        if (s_Head)    p = s_Head;
        else
        {
            s_Head = OneNode;
            s_Number++;
            return true;
        }
        if (!i)
        {
            OneNode->s_Next = s_Head;
            s_Head = OneNode;
            s_Number++;
            return true;
        }
        for (int j = 1; j < i; j++)
        {
            p = p->s_Next;
        }
        //此时p指向要插入的位置的前一个节点
        OneNode->s_Next = p->s_Next;
        p->s_Next = OneNode;
        s_Number++;
        return true;
    }
    return false;
}

template<typename T>
bool NodeList<T>::RemoveAt(int i)
{
    Node<T>*p;
    if (s_Head)    p = s_Head;
    else return false;
    if (!i)
    {
        s_Head = p->s_Next;
        delete p;
        s_Number--;
        return true;
    }
    for (int j = 1; j < i; j++)
    {
        p = p->s_Next;
    }
    //此时p指向要删除的位置的前一个节点
    Node<T>*q = p->s_Next;
    p->s_Next = p->s_Next->s_Next;
    delete q;
    s_Number--;
    return true;
}


#endif // !NODELIST_S

教师类的声明:对教师的一些信息的抽象,包含的数据及行为

#include<iostream>
#include<string>
#ifndef TEACHER_S
#define TEACHER_S
using namespace std;

class Teacher
{
private:
    const int s_ID;
    const string s_Name;
    const string s_Sex;
    int s_Age;
    string s_Major;
    string s_Number;
    float s_Money;
    int s_Pingfen;

public:
    Teacher(int Id, string Name, string Sex, int Age, string Major,string Number,float Money,int Pingfen) :
        s_ID(Id), s_Name(Name), s_Sex(Sex), s_Age(Age), s_Major(Major),s_Number(Number),s_Money(Money),s_Pingfen(Pingfen){}
    int GetID() { return s_ID; }
    int GetAge(){ return s_Age; }
    string GetMajor(){ return s_Major; }
    int GetPingfen(){ return s_Pingfen; }
    void AddAge() { s_Age++; }
    void ChangeMajor(string m) { s_Major = m; }
    void ChangeNumber(string n) { s_Number = n; }
    void ChangeMoney(float m) { s_Money = m; }
    void ChangePingfen(int p){ s_Pingfen = p; }
    friend ostream& operator<<(ostream& out, const Teacher& one)
    {
        out << one.s_ID << " " << one.s_Name << " " << one.s_Sex << " " << one.s_Age << " "
            << one.s_Major << " " << one.s_Number << " " << one.s_Money << " " << one.s_Pingfen << endl;
        return out;
    }
};
#endif // !TEACHER_S

管理类:对教师这个管理系统进行管理

#pragma once
#include<iostream>
#include"List.h"
#include"Teacher.h"
#include<fstream>

#ifndef MANAGE_S
#define MANAGE_S

class Management {
private:
    NodeList<Teacher> s_TeacherList;
public:
    Management();
    ~Management();
    void ShowAll();
    void AddTeacher();
    void DeletTeacher();
    void SearchById();
    void ChangeTeacherXinxi();
    void ShowByPaixu();
    void ReadFile();
    void WriteFile();
    void AddAllAge();
    void ClearAllDate();
};
#endif // !MANAGE_S

管理类的具体实现:

#include "Management.h"


Management::Management()
{
}


Management::~Management()
{
}

void Management::ShowAll()
{
    cout << "从左到右依次为教职工号、姓名、性别、年龄、教学科目、电话号码、月薪、评分" << endl;
    Node<Teacher>*p = s_TeacherList.GetHead();
    while (p)
    {
        cout << p->s_Data << endl;
        p = p->s_Next;
    }
}
void Management::AddTeacher()
{
    cout << "请输入教师的教职工号、姓名、性别、年龄:" << endl;
    int id, age;
    string name, sex;
    cin >> id >> name >> sex >> age;
    Node<Teacher>*p = s_TeacherList.GetHead();
    while (p)
    {
        if (p->s_Data.GetID() == id)
        {
            cout << "已有该老师的信息!添加失败" << endl;
            return;
        }
        p = p->s_Next;
    }

    cout << "请依次输入老师的教学科目、电话号码、月薪和评分:" << endl;
    string km, hm;
    float yx;
    int pf;
    cin >> km >> hm >> yx>>pf;
    Teacher one(id, name, sex, age, km, hm, yx,pf);
    if (s_TeacherList.AddAt(one, s_TeacherList.GetNum()))
        cout << "教师信息添加成功!" << endl;
    else cout << "信息添加失败!" << endl;
}

void Management::DeletTeacher()
{
    cout << "输入您想删除的教师的教职工号:";
    int id, i(0);
    cin >> id;
    Node<Teacher>*p = s_TeacherList.GetHead();
    while (p)
    {
        if (p->s_Data.GetID() == id)
        {
            if (s_TeacherList.RemoveAt(i))
                cout << "删除成功!" << endl;
            else cout << "删除失败!" << endl;
            return;
        }
        else
        {
            i++;
            p = p->s_Next;
        }
    }
    cout << "系统中没有该老师信息!" << endl;
    return;
}

void Management::SearchById()
{
    cout << "输入您想查询的教师的教职工号:";
    int id;
    cin >> id;
    Node<Teacher>*p = s_TeacherList.GetHead();
    while (p)
    {
        if (p->s_Data.GetID() == id)
        {
            cout << p->s_Data << endl;
            return;
        }
        else p = p->s_Next;
    }
    cout << "系统中没有该老师信息!" << endl;
    return;

}

void Management::ChangeTeacherXinxi()
{
    cout << "输入您想更改的老师的教职工号:";
    int id;
    cin >> id;
    Node<Teacher>*p = s_TeacherList.GetHead();
    while (p)
    {
        if (p->s_Data.GetID() == id)
        {
            cout << p->s_Data << endl;
            break;
        }
        else p = p->s_Next;
    }
    if (!p)
    {
        cout << "系统中没有该老师的信息!" << endl;
        return;
    }
    cout << "您要修改哪一样信息?(1.教学科目 2.电话号码 3.月薪 4.评分 0.返回)" << endl;
    int mark,pf;
    string k, n;
    float m;
    cin >> mark;
    if (!mark)return;
    cout << "输入修改信息:";
    if (mark == 1)
        cin >> k;
    else if (mark == 2)
        cin >> n;
    else if (mark == 3)
        cin >> m;
    else if (mark == 4)
        cin >> pf;
    switch (mark)
    {
    case 1: p->s_Data.ChangeMajor(k); break;
    case 2:p->s_Data.ChangeNumber(n); break;
    case 3:p->s_Data.ChangeMoney(m); break;
    case 4:p->s_Data.ChangePingfen(pf); break;
    default:break;
    }
    cout << "修改成功!" << endl;
    cout << p->s_Data << endl;
    return;

}
//这里采用最简单的桶排序
void Management::ShowByPaixu()
{
    cout << "请问您想根据哪一项对教师信息进行排序?" << endl
        << "(1.年龄 2.评分  0.返回)" << endl;
    int c;
    cin >> c;
    NodeList<Teacher> pucket[100];//100个桶
    Node<Teacher>*p = s_TeacherList.GetHead();
    switch (c)
    {
    case 1:
    {
              while (p)
              {
                  pucket[p->s_Data.GetAge() - 1].AddAt(p->s_Data, pucket[p->s_Data.GetAge() - 1].GetNum());
                  p = p->s_Next;
              }
              break;
    }
    case 2:
    {
              while (p)
              {
                  pucket[p->s_Data.GetPingfen() - 1].AddAt(p->s_Data, pucket[p->s_Data.GetPingfen() - 1].GetNum());
                  p = p->s_Next;
              }
              break;
    }
    case 0:break;
    default:break;
    }
    for (int i = 99; i >= 0; i--)
    {
        p = pucket[i].GetHead();
        while (p)
        {
            cout << p->s_Data << endl;
            p = p->s_Next;
        }
    }
}

void Management::ReadFile()
{
    ifstream in("data.txt");
    if (in.fail())
    {
        cout << "Data error!" << endl;
        return;
    }
    do{
        int id, age, pingfen;
        string name, sex, major, number;
        float money;
        in >> id >> name >> sex >> age >> major>> number >> money>>pingfen;
        Teacher one(id, name, sex, age, major, number, money,pingfen);
        s_TeacherList.AddAt(one, s_TeacherList.GetNum());

    } while (!in.eof());
    cout << "Read file successful!" << endl;
    in.close();
}

void Management::WriteFile()
{
    ofstream out("outdata.txt");
    if (!out)
    {
        cerr << " file error!" << endl;
        return;
    }
    Node<Teacher>*p = s_TeacherList.GetHead();
    while (p)
    {
        out << p->s_Data;
        cout << p->s_Data;
        p = p->s_Next;
    }
    cout << "Write file successful!" << endl;
    out.close();
}

void Management::AddAllAge()
{
    Node<Teacher>*p = s_TeacherList.GetHead();
    while (p)
    {
        p->s_Data.AddAge();
        p = p->s_Next;
    }
    cout << "教师年龄增加完成!" << endl;
    return;
}

void Management::ClearAllDate()
{
    if (s_TeacherList.IsEmpty())
    {
        cout << "数据已经为空!" << endl;
        return;
    }
    else if (s_TeacherList.Clear())
        cout << "删除数据成功!" << endl;
    else { 
            cout << "删除数据失败,程序退出" << endl;
            exit(0);
        }
    return;
}

主函数:菜单选项

#include<iostream>
#include<fstream>
#include <string>
#include"Management.h"
using namespace std;

int main()
{
    Management manager;
    while (1)
    {
        cout << "**********************************" << endl;
        cout << "****欢迎您使用教师信息系统********" << endl;
        cout << "*                                *" << endl;
        cout << "*  |输入数字执行您想使用的功能|  *" << endl;
        cout << "*        1.读取文件              *" << endl;
        cout << "*        2.写入文件              *" << endl;
        cout << "*        3.显示教师信息          *" << endl;
        cout << "*        4.添加教师信息          *" << endl;
        cout << "*        5.删除教师信息          *" << endl;
        cout << "*        6.更改教师信息          *" << endl;
        cout << "*        7.查询教师信息          *" << endl;
        cout << "*        8.按年龄或评分排序      *" << endl;
        cout << "*        9.增加所有老师年龄      *" << endl;
        cout << "*        10.清空所有数据         *" << endl;
        cout << "*        0.退出                  *" << endl;
        cout << "**********************************" << endl;
        int input;
        cin >> input;
        switch (input)
        {
        case 1: {manager.ReadFile(); manager.ShowAll(); break; }
        case 2: {manager.WriteFile(); break; }
        case 3: {manager.ShowAll(); break; }
        case 4: {manager.AddTeacher(); break; }
        case 5: {manager.DeletTeacher(); break; }
        case 6: {manager.ChangeTeacherXinxi(); break; }
        case 7: {manager.SearchById(); break; }
        case 8: {manager.ShowByPaixu(); break; }
        case 9: {manager.AddAllAge(); break; }
        case 10: {manager.ClearAllDate(); break; }
        case 0: exit(0);
        default:return 0;
        }
    }
    return 0;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: C++实现教师管理系统

本文链接: https://www.lsjlt.com/news/142869.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C++实现教师管理系统
    本文实例为大家分享了C++实现教师管理系统的具体代码,供大家参考,具体内容如下 链表模板定义:就是用这种数据类型来进行存储 #include<iostream> #if...
    99+
    2022-11-13
  • C++实现教务管理系统
    本文实例为大家分享了C++实现教务管理系统的具体代码,供大家参考,具体内容如下 gradeInfo.cpp #include <iostream> #include &l...
    99+
    2022-11-13
  • C++实现评教管理系统
    本文实例为大家分享了C++实现评教管理系统的具体代码,供大家参考,具体内容如下 #include<iostream> #include<fstream> #i...
    99+
    2022-11-13
  • Java实现简单的学生教师管理系统
    本文实例为大家分享了Java实现学生教师管理系统的具体代码,供大家参考,具体内容如下 需求: 我们可以通过管理系统对学生和教师进行管理对象学生和教师进行增删改查等的功能 1、Stud...
    99+
    2022-11-13
  • C++实现高校教室管理系统
    本文实例为大家分享了C++实现高校教室管理系统的具体代码,供大家参考,具体内容如下 设计目的在于,利用学习的数据结构和c语言知识,研究大学空闲教室管理系统的开发途径和应用方法。与其他...
    99+
    2022-11-13
  • C语言实现教务管理系统
    本文实例为大家分享了C语言实现教务管理系统的具体代码,供大家参考,具体内容如下 目前已完成教师管理系统部分,学生管理系统待完成: 实现效果如图: 主界面: 教师端—&...
    99+
    2022-11-13
  • C++如何实现教职工管理系统
    这篇文章主要介绍“C++如何实现教职工管理系统”,在日常操作中,相信很多人在C++如何实现教职工管理系统问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C++如何实现教职工管理系统”的疑惑有所帮助!接下来,请跟...
    99+
    2023-06-29
  • C++实现教职工信息管理系统
    本文实例为大家分享了C++实现教职工信息管理系统的具体代码,供大家参考,具体内容如下 一.问题描述 一个小公司包含四类人员:经理,技术人员,销售人员和销售经理,各类人员的工资计算方法...
    99+
    2022-11-13
  • C++实现教工考勤信息管理系统
    本文实例为大家分享了C++实现教工考勤信息管理系统的具体代码,供大家参考,具体内容如下 需求分析 传统意义上的考勤管理都是采用原始的手工操作来完成的。人事部的管理人员或办公室人员要进...
    99+
    2022-11-13
  • C语言如何实现教务管理系统
    这篇文章主要介绍“C语言如何实现教务管理系统”,在日常操作中,相信很多人在C语言如何实现教务管理系统问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C语言如何实现教务管理系统”的疑惑有所帮助!接下来,请跟着小编...
    99+
    2023-06-29
  • C++实现教职工管理系统课程设计
    本文实例为大家分享了C++实现教职工管理系统的具体代码,供大家参考,具体内容如下 要求:设计一个程序来管理职工较全面数据信息,具备数据的输入、查找、删除等功能。具体功能细节可以根据自...
    99+
    2022-11-13
  • C++怎么实现教工考勤信息管理系统
    这篇“C++怎么实现教工考勤信息管理系统”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C++怎么实现教工考勤信息管理系统”文...
    99+
    2023-06-30
  • C++实现车票管理系统
    本文实例为大家分享了C++实现车票管理系统的具体代码,供大家参考,具体内容如下 一车站每天有n个发车班次,每个班次都有一班次号(1、2、3…n),固定的发车时间,固定的...
    99+
    2022-11-13
  • C#实现学生管理系统
    本文实例为大家分享了C#实现学生管理系统的具体代码,供大家参考,具体内容如下 添加3个类,分别实现 IComparer接口,实现对Student类的三个字段的排序。 1、学生类:学号...
    99+
    2022-11-13
    C#学生管理系统 C#学生系统 C#学生管理
  • C++实现职工管理系统
    本文实例为大家分享了C++实现职工管理系统的具体代码,供大家参考,具体内容如下 workermanager.h #pragma once//防止头文件重复包含 #include...
    99+
    2022-11-12
  • C++实现酒店管理系统
    本文实例为大家分享了C++实现酒店管理系统的具体代码,供大家参考,具体内容如下 一、先看效果 1、run 2、查询   3、入住   再查询,可以看到201有人...
    99+
    2022-11-12
  • C#实现销售管理系统
    C#制作简易的的销售管理系统,供大家参考,具体内容如下 1.整体需求 1).具有简易的登录界面 2).能对商品信息进行快速查看、查询、添加、编辑、保存等功能。 2.设计的窗体界面 1...
    99+
    2022-11-12
  • C++实现考勤管理系统
    本文实例为大家分享了C++实现考勤管理系统的具体代码,供大家参考,具体内容如下 设计一考勤管理系统,记录学生的缺课情况 1、设计学生类;2、设计课程类;3、设计考勤类;4、录入学生的...
    99+
    2022-11-13
  • C++实现单词管理系统
    本文实例为大家分享了C++实现单词管理系统的具体代码,供大家参考,具体内容如下 实现功能 退出添加单词删除单词修改单词查询单词排序单词显示单词 简述 单词管理系统使用了C++语言连接...
    99+
    2022-11-13
  • C++实现信息管理系统
    本文实例为大家分享了C++实现信息管理系统的具体代码,供大家参考,具体内容如下 有一个信息管理系统,要求检查每一个登录系统的用户(User)的用户名和口令,系统检查合格以后方可登录系...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作