使用C++实现学生管理系统

2023-05-16

我在前面的博客中分别使用C语言的动态数组和链表实现了学生成绩管理系统,最近正好在学习C++,于是我便使用C++实现了学生成绩管理系统,算法和前面的C语言的动态数组实现的学生成绩管理系统差不多,只是在动态内存分配上使用了C++的New,而C语言中使用的是malloc,在排序中使用了插入排序

我的使用C语言实现的学生成绩管理系统:http://blog.csdn.net/u010105970/article/details/17752193

使用链表实现的学生成绩管理系统:http://blog.csdn.net/u010105970/article/details/25058379

插入排序:http://blog.csdn.net/u010105970/article/details/25464535

首先定义一个Student类

class Student//学生类
{
public:
	~Student();//析构函数
    void InputStudent(void);//输入学生信息
    void OutputStudent(void);//输出学生信息
    void DeleteStudent(void);//删除学生信息
    void SearchStudent(void);//查找学生信息
    void ChangeStudent(void);//修改学生信息
    void ScortByChinese(void);//对学生的语文成绩排序
    void ScortByMath(void);  //对学生的数学成绩排序
    void ScortByEnglish(void);//对学生的英语成绩排序
    void ScortByTotal(void);//对学生的总分排序
 
private:
    Student *St;     //学生类指针
    int Size;       //学生的人数    
    string Name;    //姓名
    int Age;        //年龄
    int No;         //学号
    float Score[3];//三科的成绩
    float Total;  //总分
    float Ave;   //平均分
};


然后通过各个成员函数操作Student类,算法和C语言的差不多我就不多解释


程序的全部代码

#include <iostream>
#include <cstdlib>
#include <string>

using namespace std;

class Student//学生类
{
public:
	~Student();//析构函数
    void InputStudent(void);//输入学生信息
    void OutputStudent(void);//输出学生信息
    void DeleteStudent(void);//删除学生信息
    void SearchStudent(void);//查找学生信息
    void ChangeStudent(void);//修改学生信息
    void ScortByChinese(void);//对学生的语文成绩排序
    void ScortByMath(void);  //对学生的数学成绩排序
    void ScortByEnglish(void);//对学生的英语成绩排序
    void ScortByTotal(void);//对学生的总分排序
 
private:
    Student *St;     //学生类指针
    int Size;       //学生的人数    
    string Name;    //姓名
    int Age;        //年龄
    int No;         //学号
    float Score[3];//三科的成绩
    float Total;  //总分
    float Ave;   //平均分
};

//析构函数
Student::~Student()
{
	delete(St);
}

//输入学生的信息
void Student::InputStudent(void)
{
    int len;//学生的人数
    cout<<"请输入学生的人数:";
    cin>>len;

    system("cls");

    Size = len;

    St = new Student[Size];

    for(int i=0; i<len; i++)
    {
        cout<<"请输入第"<<i+1<<"个学生的姓名:";
        cin>>St[i].Name;

        cout<<"请输入第"<<i+1<<"个学生的年龄:";
        cin>>St[i].Age;

        cout<<"请输入第"<<i+1<<"个学生的学号:";
        cin>>St[i].No;

        cout<<"请输入第"<<i+1<<"个学生的语文成绩:";
        cin>>St[i].Score[0];

        cout<<"请输入第"<<i+1<<"个学生的数学成绩:";
        cin>>St[i].Score[1];

        cout<<"请输入第"<<i+1<<"个学生的英语成绩:";
        cin>>St[i].Score[2];

        St[i].Total = St[i].Score[0] + St[i].Score[1] + St[i].Score[2];

        St[i].Ave = St[i].Total / 3.0f;

        system("cls");
    }
}

//输出学生的信息
void Student::OutputStudent(void)
{
    cout<<"姓名  年龄   学号   语文   数学  英语  总分  平均分"<<endl;

    for(int i=0; i<Size; i++)
    {
        cout<<St[i].Name<<"  "<<St[i].Age<<"  "<<St[i].No<<"  "<<St[i].Score[0]<<"  "<<St[i].Score[1]<<"  "<<St[i].Score[2]<<"  "
               <<St[i].Score[2]<<"  "<<St[i].Total<<"  "<<St[i].Ave<<endl;
    }
}

void Student::DeleteStudent(void)//删除学生信息
{
    string str;
    cout<<"请输入你需要删除的学生的姓名:";
    cin>>str;

    int num;//标记姓名相等时的下标

    //寻找姓名相等时的下标
    for(int i=0; i<Size; i++)
    {
        //当姓名相等时
        if(str == St[i].Name)
        {
            num = i;
        }
    }

    //将后面的学生向前移
    for(int j=num+1; j<Size; j++)
    {
        St[j-1] = St[j];
    }

    Size -= 1;//学生人数减少一个 
}

void Student::SearchStudent(void)//查找学生信息
{
    string name;
    cout<<"请输入你需要查找的学生的姓名:";
    cin>>name;

    int i;

    for(i=0; i<Size; i++)
    {
        if(name == St[i].Name)
        {
            break;
        }
    }

    cout<<St[i].Name<<" "<<St[i].Age<<" "<<St[i].No<<" "<<St[i].Score[0]<<" "<<St[i].Score[1]<<" "
           <<St[i].Score[2]<<" "<<St[i].Total<<" "<<St[i].Ave<<endl;
}

void Student::ChangeStudent(void)//修改学生信息
{
     string name;
    cout<<"请输入你需要修改的学生的姓名:";
    cin>>name;

    int i;

    for(i=0; i<Size; i++)
    {
        if(name == St[i].Name)
        {
            break;
        }
    }
    
    cout<<"修改前学生的信息:"<<endl;
      cout<<St[i].Name<<" "<<St[i].Age<<" "<<St[i].No<<"  "<<St[i].Score[0]<<" "<<St[i].Score[1]<<" "
           <<St[i].Score[2]<<" "<<St[i].Total<<" "<<St[i].Ave<<endl<<endl;

    cout<<"请输入学生的姓名:";
    cin>>St[i].Name;

    cout<<"请输入学生的年龄:";
    cin>>St[i].Age;

    cout<<"请输入第个学生的学号:";
    cin>>St[i].No;

    cout<<"请输入学生的语文成绩:";
    cin>>St[i].Score[0];

    cout<<"请输入学生的数学成绩:";
    cin>>St[i].Score[1];

    cout<<"请输入第学生的英语成绩:";
    cin>>St[i].Score[2];

    St[i].Total = St[i].Score[0] + St[i].Score[1] + St[i].Score[2];

    St[i].Ave = St[i].Total / 3.0f;
}

void Student::ScortByChinese(void)//对学生的语文成绩排序
{
    //提供插入数组中的数据
    for(int i=1; i<Size; i++)
    {
        int j = i-1;

        //插入数组中的数据
        Student temp = St[i];

        while(temp.Score[0] > St[j].Score[0] && j>=0)
        {
            St[j+1]  = St[j];
			
			j--;
        }

        St[++j] = temp;
    }
}

void Student::ScortByMath(void)//对学生的数学成绩排序
{
	//提供插入数组中的数据
    for(int i=1; i<Size; i++)
    {
        int j = i-1;

        //插入数组中的数据
        Student temp = St[i];

        while(temp.Score[1] > St[j].Score[1] && j>=0)
        {
            St[j+1]  = St[j];
			
			j--;
        }

        St[++j] = temp;
    }
}

void Student::ScortByEnglish(void)//对学生的英语成绩排序
{
	//提供插入数组中的数据
    for(int i=1; i<Size; i++)
    {
        int j = i-1;

        //插入数组中的数据
        Student temp = St[i];

        while(temp.Score[2] > St[j].Score[2] && j>=0)
        {
            St[j+1]  = St[j];
			
			j--;
        }

        St[++j] = temp;
    }
}

void Student::ScortByTotal(void)//对学生的总分排序
{
	//提供插入数组中的数据
    for(int i=1; i<Size; i++)
    {
        int j = i-1;

        //插入数组中的数据
        Student temp = St[i];

        while(temp.Total  > St[j].Total && j>=0)
        {
            St[j+1]  = St[j];
	
			j--;
        }

        St[++j] = temp;
    }
}

void main()
{
    cout<<"================================================================================\n"<<endl;  
    cout<<"================================================================================\n"<<endl;  
    cout<<"*************************欢迎使用学生成绩管理系统*******************************\n"<<endl;  
    cout<<"-----------------------------------------------------------------制作人:梅沙小子\n"<<endl;  
    cout<<"********************************************************************************\n"<<endl;  
    cout<<"================================================================================\n"<<endl;  
    
    cout<<"请按任意将进入学生管理系统:"<<endl;  
    getchar();  
    system("cls");  
  
    cout<<"================================================================================\n\n";  
    cout<<"------------------------ 请选择要操作的命令:-----------------------------------\n\n";  
    cout<<"-------------------------- 1 输入学生信息--------------------------------------\n\n";  
    cout<<"-------------------------- 2 输出学生信息--------------------------------------\n\n";  
    cout<<"-------------------------- 3 删除学生信息--------------------------------------\n\n";  
    cout<<"-------------------------- 4 查找学生信息--------------------------------------\n\n";  
    cout<<"-------------------------- 5 修改学生信息--------------------------------------\n\n";  
    cout<<"-------------------------- 6 将学生的语文成绩按从大到小排----------------------\n\n";  
    cout<<"-------------------------- 7 将学生的数学成绩按从大到小排----------------------\n\n";  
    cout<<"-------------------------- 8 将学生的英语成绩按从大到小排----------------------\n\n";  
    cout<<"-------------------------- 9 将学生的总成绩按从大到小排------------------------\n\n";  
    cout<<"================================================================================\n\n";  
    
    int Item;//操作命令

    Student st;//学生对象

    while(1)  
   {  
        cout<<"请选择操作命令:";  
        cin>>Item;  
        system("cls");//清屏  
  
       switch(Item)  
        {  
            case 1://输入学生信息  
            {  
                st.InputStudent();  
            }  
            break;  
  
            case 2://输出学生信息  
            {  
                st.OutputStudent();  
            }  
            break;  
  
          case 3://删除学生信息  
            {  
                st.DeleteStudent();  
           }  
            break;  
  
            case 4://查找学生信息  
            {  
                st.SearchStudent();  
            }  
            break;  
  
            case 5://修改学生信息  
            {  
               st.ChangeStudent();   
            }              
            break;  
 
            case 6://对学生的语文成绩排序  
            {  
                st.ScortByChinese();  
               st.OutputStudent();  
            }  
            break;  
  
            case 7://对学生的数学成绩排序  
            {  
                st.ScortByMath();  
                st.OutputStudent();  
            }  
            break;  
  
            case 8://对学生的英语成绩排序  
            {  
                st.ScortByEnglish();  
                st.OutputStudent();  
            }  
            break;  
  
            case 9://对学生的总分排序  
            {  
                st.ScortByTotal();  
                st.OutputStudent();
            }  
            break;  
            default:  
            break;  
        }  
    }  
  
    system("pause");  
} 



本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

使用C++实现学生管理系统 的相关文章

  • 多智能体一致性(Consensus)中的矩阵理论(Matrix Theory)

    文章目录 写在前面一致性算法连续时间离散时间 一致性证明连续时间离散时间 矩阵理论特征值和特征向量特征多项式代数重数几何重数 总结 写在前面 最近在看一些分布式优化的文章 xff0c 但是大部分文章都是用的离散时间算法 我之前一直研究的是连
  • 【论文笔记】利用平滑度加速分布式优化——梯度跟踪法(Gradient Tracking)

    文章目录 写在前面问题描述和算法收敛性证明 写在前面 原论文 xff1a Harnessing Smoothness to Accelerate Distributed Optimization 本文是Qu 20181的笔记 xff0c 主
  • 迭代器是什么,C++ STL迭代器(iterator)用法详解

    无论是序列容器还是关联容器 xff0c 最常做的操作无疑是遍历容器中存储的元素 xff0c 而实现此操作 xff0c 多数情况会选用 迭代器 xff08 iterator xff09 来实现 那么 xff0c 迭代器到底是什么呢 xff1f
  • C++ priority_queue 用法详解

    不出所料 xff0c priority queue 容器适配器定义了一个元素有序排列的队列 默认队列头部的元素优先级最高 因为它是一个队列 xff0c 所以只能访问第一个元素 xff0c 这也意味着优先级最高的元素总是第一个被处理 但是如何
  • 数据库|SQLite编程实例---在线词典

    在线词典项目实例 1 在线词典功能分析 在线词典功能分析框图 2 服务器端和客户端流程图 服务器端流程示意图 客户端流程示意图 3 服务器端和客户端源码 服务器端源码 span class token comment dict server
  • 【力扣刷题】动态规划问题的思考与总结

    文章目录 什么是动态规划解决动态规划问题的步骤基础递推算法子问题求和爬楼梯杨辉三角 子问题最值最大子序和 二维DP数组非最优子结构 买卖股票 xff08 多状态递推 xff09 打家劫舍 xff08 分治算法 xff09 贪心算法背包问题
  • 百度2014移动研发笔试题目

    答案仅供参考 一 简答题 1 简述计算机的存储系统分为哪几个层次 xff0c 为什么这样的分层能够提高程序的执行效率 所谓存储系统的层次结构 xff0c 就是把各种不同存储容量 存取速度和价格的存储器按层次结构组成多层存储器 xff0c 并
  • 横屏layout-land失效的细节问题 以及谈谈不同设置模式的优缺点

    android configChanges 61 34 orientation keyboardHidden screenSize 34 设置之后手机可以识别横屏布局 xff0c 但是不会重建 xff0c 但是pad不识别 xff0c 头疼
  • 数学公式汇总

    高等数学公式篇 平方关系 xff1a sin 2 43 cos 2 61 1 tan 2 43 1 61 sec 2 cot 2 43 1 61 csc 2 积的关系 xff1a sin 61 tan cos cos 61 cot sin
  • KEIL ARM 6.12 compiler 编译__ASM 错误的解决方法

    1 问题 KEIL compiler 设置为 use default compiler version 5 可以正确编译以下汇编和C混合代码 xff0c 更改编译器为V6 12后不识别 ASM关键字 xff0c 并对汇编语法报错 替换为 A
  • 面试题:从给定的N个正数中选取若干个数之和最接近M

    这道题跟捞鱼问题一样 xff0c 都是刚进实验室新生培训那会儿做过的题目 xff0c 不过这个是一师姐当时找工作的面试题 如题 xff0c 并输出该子序列 测试用例 xff1a 2 xff0c 9 xff0c 5 xff0c 7 xff0c
  • 贝叶斯最优分类器

    贝叶斯常常有两个问题 xff1a xff08 1 xff09 给定训练数据 xff0c 最可能的假设是什么 xff1f xff08 2 xff09 给定训练数据 xff0c 对新实例的最可能分类是什么 xff1f 第一个问题用最大后验概率
  • 奇异值分解SVD应用—LSI/LSA

    原文 xff1a http blog csdn net abcjennifer article details 8131087 xff08 有看不懂的地方 xff0c 原文评论有点解答 xff09 潜在语义索引 xff08 Latent S
  • EAGAIN、EWOULDBLOCK、EINTR与非阻塞 长连接

    EAGAIN EWOULDBLOCK EINTR与非阻塞 长连接 EWOULDBLOCK用于非阻塞模式 xff0c 不需要重新读或者写 EINTR指操作被中断唤醒 xff0c 需要重新读 写 在Linux环境下开发经常会碰到很多错误 设置e
  • WebSocket 实战

    本文介绍了 HTML5 WebSocket 的由来 xff0c 运作机制及客户端和服务端的 API 实现 xff0c 重点介绍服务端 xff08 基于 Tomcat7 xff09 及客户端 xff08 基于浏览器原生 HTML5 API x
  • FreeRTOS系列|FreeRTOS简介

    FreeRTOS简介 1 RTOS简介 RTOS全称为 Real Time Operation System xff0c 即实时操作系统 RTOS强调的是实时性 xff0c 又分为硬实时和软实时 硬实时要求在规定的时间内必须完成操作 xff
  • makefile 编写之32 or 64位机器

    一 Makefile 判断 64位机器 ARCH 61 shell uname m BIT32 61 i686 BIT64 61 x86 64 all clean ifeq ARCH BIT64 64 echo x86 64 make Su
  • linux多行注释

    1 多行注释 xff1a 1 首先按esc进入命令行模式下 xff0c 按下Ctrl 43 v xff0c 进入列 xff08 也叫区块 xff09 模式 2 在行首使用上下键选择需要注释的多行 3 按下键盘 xff08 大写 xff09
  • linux多线程信号处理

    在linux下 xff0c 每个进程都有自己的signal mask xff0c 这个信号掩码指定哪个信号被阻塞 xff0c 哪个不会被阻塞 xff0c 通常用调用sigmask来处理 同时每个进程还有自己的signal action xf
  • Mysql的row_format

    问题描述 xff1a You have an error in your SQL syntax check the manual that corresponds to your MySQL server version for the r

随机推荐

  • MetricsSystem

    Metrics xff0c 我们听到的太多了 xff0c 熟悉大数据系统的不可能没听说过metrics xff0c 当我们需要为某个系统某个服务做监控 做统计 xff0c 就需要用到Metrics 举个例子 xff0c 一个图片压缩服务 x
  • Hazelcast集群服务(1)——Hazelcast介绍

    https www cnblogs com hunter 56213 p 6230442 html Hazelcast是什么 分布式 集群服务 网格式内存数据 分布式缓存 弹性可伸缩服务 这些牛逼闪闪的名词拿到哪都是ITer装逼的不二之选
  • 小议同步IO :fsync与fdatasync

    对于提供事务支持的数据库 xff0c 在事务提交时 xff0c 都要确保事务日志 xff08 包含该事务所有的修改操作以及一个提交记录 xff09 完全写到硬盘上 xff0c 才认定事务提交成功并返回给应用层 一个简单的问题 xff1a 在
  • 阿里云 李博

    机器学习基础知识 业务架构 xff1b 算法代替人类思考 xff0c 实现生产力飞跃 xff0c xff1b 大部分开源工具封装了算法 xff1b 无需算法开发以及算法的公式推导 xff1b 如何使用算法解决自身的应用场景 xff1b 业务
  • thinkphp中display调用模板文件详…

    模板变量赋值后就需要调用模板文件来输出相关的变量 xff0c 模板调用通过display方法来实现 我们在操作方法的最后使用 xff1a this gt display 就可以输出模板 xff0c 根据前面的模板定义规则 xff0c 因为系
  • 遥控器与电调相关知识点整理

    一 xff0c 电调的控制方法 PWM 单片机输出1ms 2ms的方波脉冲 xff0c 根据航模标准 xff0c PWM信号线的频率应该是50Hz xff0c 对应的每个周期总时长是20ms xff0c 输出到电调的油门线 xff08 控制
  • FreeRTOS系列|开发环境

    开发环境搭建 1 硬件开发环境 FreeRTOS系列所使用的硬件为STM32F103ZET6开发板 2 软件开发环境 2 1 Keil MDK ARM软件简介及安装 2 1 1 Keil MDK ARM简介 Keil MDK xff0c 也
  • 陀螺仪加速度计MPU6050

    转载自 xff1a http www crazepony com wiki mpu6050 html 陀螺仪 陀螺仪 xff0c 测量角速度 xff0c 具有高动态特性 xff0c 它是一个间接测量角度的器件 它测量的是角度的导数 xff0
  • 机器学习-Anomaly Detection

    Problem Motivation 异常检测 Anomaly detection 是机器学习算法的一个常见应用 这种算法的一个有趣之处在于 xff1a 它虽然主要用于非监督学习问题 xff0c 但从某些角度看 xff0c 它又类似于一些监
  • Quadrotor四旋翼飞行器的飞…

    原文地址 xff1a Quadrotor四旋翼飞行器的飞行原理 xff08 一 xff09 作者 xff1a hxl85 http en wikipedia org wiki Quadrotor 这是wiki上的介绍 xff0c 有兴趣可以
  • 姿态解算知识(三)-陀螺仪加速度计6轴数据融合

    这么久的惯导总算是没白看 xff0c 加上一篇博客的指点 xff0c 这两天把Mahony的九轴数据融合算法看懂了 可惜第二版硬件还没到 xff0c 磁力计用不了 xff0c 没法验证效果 今天先总结下陀螺仪和加速度计的六轴数据融合 版权声
  • (含代码)ESP8266+舵机 制作wifi灯控开关(arduino,点灯科技,小爱同学/天猫精灵实现)

    目录 项目涉及的主代码 前言 一 环境搭建 二 开发步骤 1 注册点灯科技平台 2 在点灯科技平台注册设备 xff0c 获取Secret Key 3 在Arduino IDE中编写代码 xff0c 写入ESP8266 4 编译固件 xff0
  • C语言实现学生成绩管理系统

    学生管理系统 主界面 功能选择界面 所用的函数 函数名 int Num void 函数功能 得到学生人数 函数代码 得到学生人数 int Num void printf 34 请输入学生的人数 n 34 scanf 34 d 34 amp
  • 因式分解

    因式分解是数学中一种常见的计算 xff0c 也是编程中一种非常常见的编程方法 因式分解是指将一个非质数分解成几个质数的积 如 xff1a 4 61 2x2 100 61 2x2x5x5 算法代码 xff1a include lt stdio
  • 在控制台程序中播放音乐

    看过我的博客的人都知道 xff0c 在C语言中调用几个API函数就可以播放音乐了 xff0c 而我在博客中也写过Windows图形界面编程中做过一些与音乐有关的程序 xff0c 如 音乐播放器 音乐贺卡 等 xff0c 可是如果要你在控制台
  • 常用的DOS命令

    xfeff xfeff CMD命令 xff1a 开始 xff0d gt 运行 xff0d gt 键入cmd或command xff08 在命令行里可以看到系统版本 文件系统版本 xff09 1 appwiz cpl xff1a 程序和功能
  • FreeRTOS系列|任务基础知识

    任务基础知识 1 多任务系统 1 1 前后台系统 单片机裸机开发时 xff0c 一般都是在main函数里面用while 1 做一个大循环来完成所有的处理 xff0c 循环中调用相应的函数完成所需的处理 有时也需要在中断中完成一些处理 相对于
  • 链表《5》使用链表实现学生成绩管理系统

    上次我使用动态数组结构体实现了学生成绩管理系统 xff1a http blog csdn net u010105970 article details 17752193 这次学习了链表对链表也有所了解 xff0c 我就想着用链表实现学生成绩
  • 得到一个数字中每一位的数字

    学习编程也有一段时间了 xff0c 随着学习的不断深入 xff0c 我越来越体会到了算法的重要性 xff0c 最近遇到了一些非常有意思的算法 xff0c 比如打印水仙花数 将数字逆置 xff0c 在这两个算法中会用到一个数字钟每一位的值 如
  • 使用C++实现学生管理系统

    我在前面的博客中分别使用C语言的动态数组和链表实现了学生成绩管理系统 xff0c 最近正好在学习C 43 43 xff0c 于是我便使用C 43 43 实现了学生成绩管理系统 xff0c 算法和前面的C语言的动态数组实现的学生成绩管理系统差