从0到1入门C++编程——12 演讲比赛流程管理系统

文章目录

  • 一、创建类并显示菜单
  • 二、退出管理系统
  • 三、开始演讲比赛
  • 四、查看往届记录
  • 五、清空比赛记录
  • 六、案例源代码


演讲比赛流程管理系统
比赛规则:演讲比赛共有12个人参加,比赛分两轮进行,第一轮为淘汰赛,第二轮为决赛。每名选手都有对应的编号,如10001~10012,可以根据届数的不同修改选手编号,第一轮分为两个小组,每组6个人,整体按照选手编号进行抽签后顺序演讲。十个评委分别给每名选手打分,去除最高分和最低分,平均分作为本轮选手的成绩。第一轮过后,分别淘汰两组内排名后三名的选手,每组前三名晋级。第二轮为决赛,前三名胜出,每轮比赛过后需要显示晋级选手的信息。
程序功能
开始演讲比赛:完成整届比赛的流程,每个比赛阶段需要给用户一个提示,用户按任意键后继续下一个阶段;
查看往届记录:查看之前比赛前三名结果,每次比赛都会记录到文件中,文件用.csv后缀名保存;
清空比赛记录:将文件中数据清空;
退出比赛程序:用户输入某一选择后退出程序。


一、创建类并显示菜单

创建管理类头文件和cpp文件,在头文件中创建一个类,后续相关的成员函数在类中进行声明,具体的实现在cpp文件中。
在这里插入图片描述
菜单显示功能的实现步骤:先在头文件speechManager.h中声明显示菜单的函数,然后在speechManager.cpp中实现该函数,再到main.cpp中通过实例化对象调用该函数接口。之后的功能基本上都是按照这个步骤进行的。
头文件speechManager.h中声明显示菜单函数的代码如下。

#pragma once
#include <iostream>
using namespace std;class speechManager
{
public:speechManager();  //构造函数void show_menu();  //显示菜单~speechManager();  //析构函数
};

在speechManager.cpp中实现显示菜单的代码如下。

void speechManager::show_menu()  //显示菜单
{cout<<"****************************************"<<endl;cout<<"**********演讲比赛流程管理系统**********"<<endl;cout<<"**********   0.退出比赛程序   **********"<<endl;cout<<"**********   1.开始演讲比赛   **********"<<endl;cout<<"**********   2.查看往届记录   **********"<<endl;cout<<"**********   3.清空比赛记录   **********"<<endl;cout<<"****************************************"<<endl;cout<<endl;
}

main.cpp中通过实例化对象调用该函数接口的代码如下。

speechManager sp;
sp.show_menu();  //显示菜单

运行程序后的结果如下图所示。
在这里插入图片描述


二、退出管理系统

speechManager.cpp中实现退出管理系统的代码如下。

void speechManager::exit_system()  //退出系统
{cout<<"欢迎下次使用!"<<endl;system("pause");exit(0);
}

main.cpp中通过switch-case分支对用户的输入进行不同的处理,到此为止的代码框架如下。

int user_choice;
speechManager sp;
while(1)
{sp.show_menu();  //显示菜单cout<<"请输入您的选择: ";cin>>user_choice;switch(user_choice){case 0:sp.exit_system();  //退出系统break;case 1:break;case 2:break;case 3:break;default:system("cls");  //清屏break;}
}

运行程序之后输入0,按回车后显示如下,再按任意键就会退出该程序。
在这里插入图片描述


三、开始演讲比赛

本案例中内容最多的就是演讲比赛功能,在管理类中添加下面各项属性。

vector<int> v1;  //第一轮比赛12人
vector<int> v2;  //第二轮比赛6人
vector<int> v;  //获胜者3人
map<int,Person> m;  //存放选手和编号的容器
int round;  //比赛轮数
bool fileIsEmpty;  //判断文件是否为空
map<int,vector<string>> m_record;  //读取文件记录
int session;  //记录比赛届数

在speechManager.h中创建选手类如下。

class Person
{
public:string name;  //选手姓名double score[2];  //记录平均分,有两轮
};

在构造函数中初始化各项参数、创建比赛选手、然后从文件中加载往届的记录信息,构造函数的内容如下。

speechManager::speechManager()  //构造函数
{init_index();    //初始化各项参数read_from_file();  //加载往届记录信息,读取到session供create_person()使用create_person();  //创建选手
}

构造函数中调用的各函数如下。

void speechManager::init_index() //初始化
{this->v1.clear();  //清空各容器this->v2.clear();this->v.clear();this->m.clear();this->round = 1;  //第一轮this->m_record.clear();
}void speechManager::read_from_file()  //从文件读取信息
{ifstream ifs("speech.cvs",ios::in);if(!ifs.is_open()){fileIsEmpty = true;//cout<<"文件不存在!"<<endl;session = 0;  //第0届ifs.close();return;}char ch;ifs>>ch;  //先读一个字符if(ifs.eof())  //文件被清空的情况{//cout<<"文件为空!"<<endl;fileIsEmpty = true;session = 0;  //第0届ifs.close();return;}fileIsEmpty = false;  //以上两个if都不满足,说明文件有内容ifs.putback(ch);   //将上面读取的单个字符放回文件中string data;int line = 0;    //记录行数,每一行就是一届的信息while(ifs>>data)  //逐行读取到data中{vector<string> vs; //存放拆分后的字符串int pos = -1;int start = 0;while(1)  //拆分字符串{pos = data.find(",",start);  //从start位置开始找第一个,if(pos == -1){break;  //没找到}string temp = data.substr(start,pos-start);   //截取子串start = pos + 1;   //移动下一次开始找的位置vs.push_back(temp);  //将拆分得到的字符串存入容器中}this->m_record.insert(make_pair(line,vs));  //将届数和记录存入map容器中line++;session = line;  //记录届数//cout<<line<<" data: "<<data<<endl;}ifs.close();
}void speechManager::create_person()  //创建选手
{session++;  //届数string nameSeed = "ABCDEFGHIJKL";for(int i=0;i<nameSeed.size();i++){string name = "选手";name += nameSeed[i];Person p;p.name = name;  //姓名p.score[0] = 0;  //分数都初始化为0p.score[1] = 0;v1.push_back(session*10000+1+i);   //根据届数给选手编号,并插入到vector容器中m.insert(make_pair<int,Person>(session*10000+1+i,p));  //插入到map容器中}
}

正式开始演讲比赛后,分两轮进行,每轮比赛需要进行抽签决定顺序,存放评委打分,显示本轮晋级结果,并在第二轮结束后将本届比赛获胜的三位选手信息写入文件中。

void speechManager::start_speech()  //开始比赛,控制整个流程
{//第一轮比赛speech_draw(); //1.抽签确定比赛顺序speech_contest(); //2.开始比赛并打分show_score();  //3.显示晋级结果//第二轮比赛this->round++;speech_draw();  //1.抽签确定比赛顺序speech_contest(); //2.开始比赛并打分show_score(); //3.显示最终获胜结果save_to_file(); //4.保存分数到文件中cout<<"本次比赛结束!"<<endl;init_index();  //初始化各项参数read_from_file();  //加载往届记录信息create_person();  //创建选手system("pause");system("cls");
}

演讲比赛过程中用到的各个函数如下。

void speechManager::speech_draw()   //抽签
{cout<<"-----------------------"<<endl;cout<<"第"<<this->round<<"轮比赛选手正在抽签..."<<endl;cout<<"-----------------------"<<endl;cout<<"抽签后的演讲顺序如下: "<<endl;if(this->round == 1)  //第一轮抽签{random_shuffle(v1.begin(),v1.end());   //洗牌,打乱v1容器中的编号顺序for(vector<int>::iterator i=v1.begin();i!=v1.end();i++){cout<<*i<<" ";}cout<<endl;}else   //第二轮抽签{random_shuffle(v2.begin(),v2.end());   //洗牌,打乱v2容器中的编号顺序for(vector<int>::iterator i=v2.begin();i!=v2.end();i++){cout<<*i<<" ";}cout<<endl;}cout<<endl;system("pause");cout<<endl;
}void speechManager::speech_contest()  //开始比赛并打分
{cout<<"------------ 第"<<this->round<<"轮比赛开始 ------------"<<endl;multimap<double,int,greater<double>> group;  //防止同分情况定义为multimap容器,降序排列6个人的成绩和编号//这里把得分放在编号前面是为了降序排列得分,map容器是按照第一个位置的参数排序的int num = 0;    //记录小组内成员个数,6人一组vector<int> vtemp;  //创建一个临时容器,根据当前比赛轮数进行拷贝操作if(this->round == 1){vtemp = v1;  //第一轮}else{vtemp = v2;   //第二轮}for(vector<int>::iterator i=vtemp.begin();i!=vtemp.end();i++){num++;deque<double> d;  //存取评委打分,deque容器排序后容易去掉开头末尾两数for(int j=0;j<10;j++){double score = (rand()%401+600)/10.f;  //60.0-100.0d.push_back(score);}sort(d.begin(),d.end(),greater<double>());  //降序排列d.pop_front();  //去除最高分d.pop_back();  //去除最低分double aver = accumulate(d.begin(),d.end(),0.0f) / (double) d.size();  //累加总分并求平均分this->m[*i].score[round-1] = aver;  //将平均分存放在map容器中//cout<<"编号: "<<*i<<" 姓名: "<<m[*i].name<<" 平均分: "<<m[*i].score[round-1]<<endl;group.insert(make_pair<double,int>(aver,*i));   //插入临时容器中,key是得分,value是选手编号if(num % 6 == 0)  //num = 6 或 num = 12 时进入{cout<<"********** 第"<<num/6<<"小组的排名如下 **********"<<endl;int count = 0;for(multimap<double,int,greater<double>>::iterator i=group.begin();i!=group.end();i++){cout<<"编号: "<<i->second<<" 姓名: "<<m[i->second].name<<" 平均分: "<<m[i->second].score[round-1]<<endl;if(count < 3)  //取前三名{if(this->round == 1){v2.push_back(i->second);  //晋级第二轮的选手}else{v.push_back(i->second);  //最终获胜的选手}count++;}}group.clear();  //每6人就清空一次容器}}cout<<"------------ 第"<<this->round<<"轮比赛结束 ------------"<<endl;cout<<endl;system("pause");cout<<endl;
}void speechManager::show_score()  //显示晋级结果
{cout<<"-------- 第"<<this->round<<"轮晋级选手信息如下 --------"<<endl;vector<int> vtemp;  //创建一个临时容器,根据当前比赛轮数进行拷贝操作if(this->round == 1){vtemp = v2;}else{vtemp = v;}for(vector<int>::iterator i=vtemp.begin();i!=vtemp.end();i++){cout<<"编号: "<<*i<<" 姓名: "<<m[*i].name<<" 平均分: "<<m[*i].score[round-1]<<endl;}cout<<"---------------------------------------"<<endl;cout<<endl;system("pause");system("cls");show_menu();
}void speechManager::save_to_file()  //将晋级信息保存到文件
{ofstream ofs;ofs.open("speech.cvs",ios::out | ios::app);   //用追加的方式往文件中写数据for(vector<int>::iterator i=v.begin();i!=v.end();i++){ofs<<*i<<","<<m[*i].score[1]<<",";}ofs<<endl;ofs.close();cout<<"数据已保存!"<<endl;fileIsEmpty = false;   //插入数据后文件已经不为空
}

抽签过程如下图所示。
在这里插入图片描述
第一轮比赛结束后,每个小组按照得分从高到低排列,每个小组取前三名晋级下一轮,如下图所示。
在这里插入图片描述
第二轮抽签、赛果及晋级信息如下图所示。
在这里插入图片描述
本次比赛结束后将获胜三人的信息存入文件中,方便后续访问。
在这里插入图片描述


四、查看往届记录

read_from_file()函数中已经将文件中保存的记录读取到了map容器中,现在查看往届记录只需要从map容器中读取信息即可。
查看往届记录的函数体如下。

void speechManager::show_record()  //显示往届记录
{if(fileIsEmpty){cout<<"文件为空或不存在!"<<endl;}else{for(int i=0;i<m_record.size();i++){cout<<"第"<<i+1<<"届---冠军编号:"<<m_record[i][0]<<" 分数:"<<m_record[i][1]<<"   亚军编号:"<<m_record[i][2]<<" 分数:"<<m_record[i][3]<<"   季军编号:"<<m_record[i][4]<<" 分数:"<<m_record[i][5]<<endl;}/*for(map<int,vector<string>>::iterator i=m_record.begin();i!=m_record.end();i++){cout<<"第"<<i->first+1<<"届---冠军编号:"<<i->second[0]<<" 分数:"<<i->second[1]<<"   亚军编号:"<<i->second[2]<<" 分数:"<<i->second[3]<<"   季军编号:"<<i->second[4]<<" 分数:"<<i->second[5]<<endl;}*/}system("pause");system("cls");
}

读取往届记录信息的截图如下图所示。
在这里插入图片描述
往届记录在项目工程文件夹下的speech.cvs文件中存放的信息如下。
在这里插入图片描述


五、清空比赛记录

清空比赛记录前让用户再确认一次,确认无误后将存取记录的文件删空,这样以往的比赛记录就不存在了,同时还要执行构造函数中执行的几个函数进行初始化操作。
清空比赛记录的函数体如下。

void speechManager::clear_record()  //清空往届记录
{if(fileIsEmpty){cout<<"文件为空!"<<endl;}else{cout<<"确定清空文件?"<<endl;cout<<"输入 1---确定"<<endl;cout<<"其他键---取消"<<endl;int input = 0;cin>>input;if(input == 1){ofstream ofs("speech.cvs",ios::trunc);  //删除文件并重新创建同名文件ofs.close();init_index();    //初始化各项参数session = 0;  //第0届create_person();  //创建选手read_from_file();  //加载往届记录信息cout<<"清空往届比赛记录成功!"<<endl;}}system("pause");system("cls");
}

清空比赛记录的操作截图如下图所示。
在这里插入图片描述
再次查看往届记录,提示文件为空或不存在,打开文件,里面的内容也被清空了,如下图所示。
在这里插入图片描述


六、案例源代码

speechManager.h文件的代码如下。

#pragma once
#include <iostream>
#include <vector>
#include <map>
#include <string>
#include <algorithm>
#include <functional>
#include <numeric>
#include <deque>
#include <fstream>
using namespace std;class Person
{
public:string name;  //选手姓名double score[2];  //记录平均分,有两轮
};class speechManager
{
public:speechManager();  //构造函数void show_menu();  //显示菜单void exit_system();  //退出系统void init_index();  //初始化void create_person();  //创建选手void start_speech();  //开始比赛,控制整个流程void speech_draw();  //抽签void speech_contest();  //开始比赛并打分void show_score();  //显示晋级结果void save_to_file();  //将晋级信息保存到文件void read_from_file();  //从文件读取信息void show_record();  //显示往届记录void clear_record();  //清空往届记录~speechManager();  //析构函数vector<int> v1;  //第一轮比赛12人vector<int> v2;  //第二轮比赛6人vector<int> v;  //获胜者3人map<int,Person> m;  //存放选手和编号的容器int round;  //比赛轮数bool fileIsEmpty;  //判断文件是否为空map<int,vector<string>> m_record;  //读取文件记录int session;  //记录比赛届数
};

speechManager.cpp文件的代码如下。

#include "speechManager.h"speechManager::speechManager()  //构造函数
{init_index();    //初始化各项参数read_from_file();  //加载往届记录信息,读取到session供create_person()使用create_person();  //创建选手
}void speechManager::show_menu()  //显示菜单
{cout<<"****************************************"<<endl;cout<<"**********演讲比赛流程管理系统**********"<<endl;cout<<"**********   0.退出比赛程序   **********"<<endl;cout<<"**********   1.开始演讲比赛   **********"<<endl;cout<<"**********   2.查看往届记录   **********"<<endl;cout<<"**********   3.清空比赛记录   **********"<<endl;cout<<"****************************************"<<endl;cout<<endl;
}void speechManager::exit_system()  //退出系统
{cout<<"欢迎下次使用!"<<endl;system("pause");exit(0);
}void speechManager::init_index() //初始化
{this->v1.clear();  //清空各容器this->v2.clear();this->v.clear();this->m.clear();this->round = 1;  //第一轮this->m_record.clear();
}void speechManager::create_person()  //创建选手
{session++;  //届数string nameSeed = "ABCDEFGHIJKL";for(int i=0;i<nameSeed.size();i++){string name = "选手";name += nameSeed[i];Person p;p.name = name;  //姓名p.score[0] = 0;  //分数都初始化为0p.score[1] = 0;v1.push_back(session*10000+1+i);   //根据届数给选手编号,并插入到vector容器中m.insert(make_pair<int,Person>(session*10000+1+i,p));  //插入到map容器中}
}void speechManager::speech_draw()   //抽签
{cout<<"-----------------------"<<endl;cout<<"第"<<this->round<<"轮比赛选手正在抽签..."<<endl;cout<<"-----------------------"<<endl;cout<<"抽签后的演讲顺序如下: "<<endl;if(this->round == 1)  //第一轮抽签{random_shuffle(v1.begin(),v1.end());   //洗牌,打乱v1容器中的编号顺序for(vector<int>::iterator i=v1.begin();i!=v1.end();i++){cout<<*i<<" ";}cout<<endl;}else   //第二轮抽签{random_shuffle(v2.begin(),v2.end());   //洗牌,打乱v2容器中的编号顺序for(vector<int>::iterator i=v2.begin();i!=v2.end();i++){cout<<*i<<" ";}cout<<endl;}cout<<endl;system("pause");cout<<endl;
}void speechManager::speech_contest()  //开始比赛并打分
{cout<<"------------ 第"<<this->round<<"轮比赛开始 ------------"<<endl;multimap<double,int,greater<double>> group;  //防止同分情况定义为multimap容器,降序排列6个人的成绩和编号//这里把得分放在编号前面是为了降序排列得分,map容器是按照第一个位置的参数排序的int num = 0;    //记录小组内成员个数,6人一组vector<int> vtemp;  //创建一个临时容器,根据当前比赛轮数进行拷贝操作if(this->round == 1){vtemp = v1;  //第一轮}else{vtemp = v2;   //第二轮}for(vector<int>::iterator i=vtemp.begin();i!=vtemp.end();i++){num++;deque<double> d;  //存取评委打分,deque容器排序后容易去掉开头末尾两数for(int j=0;j<10;j++){double score = (rand()%401+600)/10.f;  //60.0-100.0d.push_back(score);}sort(d.begin(),d.end(),greater<double>());  //降序排列d.pop_front();  //去除最高分d.pop_back();  //去除最低分double aver = accumulate(d.begin(),d.end(),0.0f) / (double) d.size();  //累加总分并求平均分this->m[*i].score[round-1] = aver;  //将平均分存放在map容器中//cout<<"编号: "<<*i<<" 姓名: "<<m[*i].name<<" 平均分: "<<m[*i].score[round-1]<<endl;group.insert(make_pair<double,int>(aver,*i));   //插入临时容器中,key是得分,value是选手编号if(num % 6 == 0)  //num = 6 或 num = 12 时进入{cout<<"********** 第"<<num/6<<"小组的排名如下 **********"<<endl;int count = 0;for(multimap<double,int,greater<double>>::iterator i=group.begin();i!=group.end();i++){cout<<"编号: "<<i->second<<" 姓名: "<<m[i->second].name<<" 平均分: "<<m[i->second].score[round-1]<<endl;if(count < 3)  //取前三名{if(this->round == 1){v2.push_back(i->second);  //晋级第二轮的选手}else{v.push_back(i->second);  //最终获胜的选手}count++;}}group.clear();  //每6人就清空一次容器}}cout<<"------------ 第"<<this->round<<"轮比赛结束 ------------"<<endl;cout<<endl;system("pause");cout<<endl;
}void speechManager::show_score()  //显示晋级结果
{cout<<"-------- 第"<<this->round<<"轮晋级选手信息如下 --------"<<endl;vector<int> vtemp;  //创建一个临时容器,根据当前比赛轮数进行拷贝操作if(this->round == 1){vtemp = v2;}else{vtemp = v;}for(vector<int>::iterator i=vtemp.begin();i!=vtemp.end();i++){cout<<"编号: "<<*i<<" 姓名: "<<m[*i].name<<" 平均分: "<<m[*i].score[round-1]<<endl;}cout<<"---------------------------------------"<<endl;cout<<endl;system("pause");system("cls");show_menu();
}void speechManager::save_to_file()  //将晋级信息保存到文件
{ofstream ofs;ofs.open("speech.cvs",ios::out | ios::app);   //用追加的方式往文件中写数据for(vector<int>::iterator i=v.begin();i!=v.end();i++){ofs<<*i<<","<<m[*i].score[1]<<",";}ofs<<endl;ofs.close();cout<<"数据已保存!"<<endl;fileIsEmpty = false;   //插入数据后文件已经不为空
}void speechManager::start_speech()  //开始比赛,控制整个流程
{//第一轮比赛speech_draw(); //1.抽签确定比赛顺序speech_contest(); //2.开始比赛并打分show_score();  //3.显示晋级结果//第二轮比赛this->round++;speech_draw();  //1.抽签确定比赛顺序speech_contest(); //2.开始比赛并打分show_score(); //3.显示最终获胜结果save_to_file(); //4.保存分数到文件中cout<<"本次比赛结束!"<<endl;init_index();  //初始化各项参数read_from_file();  //加载往届记录信息create_person();  //创建选手system("pause");system("cls");
}void speechManager::read_from_file()  //从文件读取信息
{ifstream ifs("speech.cvs",ios::in);if(!ifs.is_open()){fileIsEmpty = true;//cout<<"文件不存在!"<<endl;session = 0;  //第0届ifs.close();return;}char ch;ifs>>ch;  //先读一个字符if(ifs.eof())  //文件被清空的情况{//cout<<"文件为空!"<<endl;fileIsEmpty = true;session = 0;  //第0届ifs.close();return;}fileIsEmpty = false;  //以上两个if都不满足,说明文件有内容ifs.putback(ch);   //将上面读取的单个字符放回文件中string data;int line = 0;    //记录行数,每一行就是一届的信息while(ifs>>data)  //逐行读取到data中{vector<string> vs; //存放拆分后的字符串int pos = -1;int start = 0;while(1)  //拆分字符串{pos = data.find(",",start);  //从start位置开始找第一个,if(pos == -1){break;  //没找到}string temp = data.substr(start,pos-start);   //截取子串start = pos + 1;   //移动下一次开始找的位置vs.push_back(temp);  //将拆分得到的字符串存入容器中}this->m_record.insert(make_pair(line,vs));  //将届数和记录存入map容器中line++;session = line;  //记录届数//cout<<line<<" data: "<<data<<endl;}ifs.close();
}void speechManager::show_record()  //显示往届记录
{if(fileIsEmpty){cout<<"文件为空或不存在!"<<endl;}else{//for(int i=0;i<m_record.size();i++)//{//	cout<<"第"<<i+1<<"届---冠军编号:"<<m_record[i][0]<<" 分数:"<<m_record[i][1]//		<<"   亚军编号:"<<m_record[i][2]<<" 分数:"<<m_record[i][3]//		<<"   季军编号:"<<m_record[i][4]<<" 分数:"<<m_record[i][5]<<endl;//}for(map<int,vector<string>>::iterator i=m_record.begin();i!=m_record.end();i++){cout<<"第"<<i->first+1<<"届---冠军编号:"<<i->second[0]<<" 分数:"<<i->second[1]<<"   亚军编号:"<<i->second[2]<<" 分数:"<<i->second[3]<<"   季军编号:"<<i->second[4]<<" 分数:"<<i->second[5]<<endl;}}system("pause");system("cls");
}void speechManager::clear_record()  //清空往届记录
{if(fileIsEmpty){cout<<"文件为空!"<<endl;}else{cout<<"确定清空文件?"<<endl;cout<<"输入 1---确定"<<endl;cout<<"其他键---取消"<<endl;int input = 0;cin>>input;if(input == 1){ofstream ofs("speech.cvs",ios::trunc);  //删除文件并重新创建同名文件ofs.close();init_index();    //初始化各项参数session = 0;  //第0届create_person();  //创建选手read_from_file();  //加载往届记录信息cout<<"清空往届比赛记录成功!"<<endl;}}system("pause");system("cls");
}speechManager::~speechManager()  //析构函数
{}

main.cpp文件的代码如下。

#include <ctime>
#include "speechManager.h"
using namespace std;int main()
{srand((unsigned int)time(NULL));   //随机数种子int user_choice;  //用户选择speechManager sp;  //实例化对象while(1){sp.show_menu();   //显示菜单cout<<"请输入您的选择: ";cin>>user_choice;switch(user_choice){case 0:sp.exit_system();  //退出系统break;case 1:sp.start_speech();  //开始演讲比赛break;case 2:sp.show_record();  //查看往届记录break;case 3: sp.clear_record();  //清空比赛记录break;default:system("cls");  //清屏break;}}system("pause");return 0;
}

本文参考视频:
黑马程序员匠心之作|C++教程从0到1入门编程,学习编程不再难

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/742955.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HTML万字学习总结

html文本标签特殊符号图片音频与视频超链接表单列表表格语义标签(布局) html文本标签 标签简介根目录规定文档相关的配置信息&#xff08;元数据元素表示文档的内容表示那些不能由其它 HTML 元相关元素&#xff08;(<base>、<link>, <script>、<style>…

今日AI:GPT-4.5意外曝光可能6月发布、UP主借AI识别情绪播放量186万、全球首个AI程序员诞生

欢迎来到【今日AI】栏目!这里是你每天探索人工智能世界的指南&#xff0c;每天我们为你呈现AI领域的热点内容&#xff0c;聚焦开发者&#xff0c;助你洞悉技术趋势、了解创新AI产品应用。 新鲜AI产品点击了解:AIbase - 智能匹配最适合您的AI产品和网站 &#x1f4e2;一分钟速…

如何拆解技术瓶颈的难点

以大化小的思路 解决一个一个小问题从而解决最终问题 三段论&#xff1a; 抽象能力 职责领域划分 分层构建解决方案 案例&#xff1a;全局分布式事务的解决方案 抽象能力&#xff1a;全局分布式 是由一个个小的事务组合而成的&#xff0c;其中一个分布式事务出现问题&#xff…

探索考古文字场景,基于YOLOv8全系列【n/s/m/l/x】参数模型开发构建文本考古场景下的甲骨文字符图像检测识别系统

甲骨文是一种非常历史悠久的古老文字&#xff0c;在前面我们基本上很少有涉及这块的内容&#xff0c;最近正好在做文字相关的项目开发研究&#xff0c;就想着基于甲骨文的场景来开发对应的检测识别系统&#xff0c;在前文中我们基于YOLOv5、YOLOv7和YOLOv9开发构建了在仿真数据…

激活函数Mish

paper&#xff1a;Mish: A Self Regularized Non-Monotonic Activation Function official implementation&#xff1a;https://github.com/digantamisra98/Mish 背景 在早期文献中&#xff0c;Sigmoid和TanH激活函数被广泛使用&#xff0c;随后在深度神经网络中失效。相比于…

Springboot的配置文件及其优先级

配置文件 内置配置文件 配置文件的作用&#xff1a;修改SpringBoot自动配置的默认值&#xff1b;SpringBoot在底层都给我们自动配置好&#xff1b;SpringBoot使用一个全局的配置文件&#xff0c;配置文件名是固定的&#xff1a; application.propertiesapplication.yml 以上…

网络建设与运维培训介绍和能力介绍

1.开过的发票 3.培训获奖的证书 4合同签署 5.实训设备

[ThinkPHP]Arr返回1

$detailId (int)Arr::get($detail, null); var_dump($detailId); 打印结果&#xff1a;int(1) 原因&#xff1a; vendor/topthink/think-helper/src/helper/Arr.php

干洗店管理系统洗鞋店预约上门小程序洗护流程;

干洗店洗鞋店收银管理系统&#xfe63;智能线上预约洗衣店小程序软件; 闪站侠洗衣洗鞋店收银管理系统&#xff0c;一款集进销存、收衣、收银、会员管理等实用功能于一体的洗护管理软件&#xff0c;适用于各大中小型企业个体工商户&#xff0c;功能强大&#xff0c;操作简单&…

瑞_23种设计模式_命令模式

文章目录 1 命令模式&#xff08;Command Pattern&#xff09;1.1 介绍1.2 概述1.3 命令模式的结构1.4 命令模式的优缺点1.5 命令模式的使用场景 2 案例一2.1 需求2.2 代码实现 3 案例二3.1 需求3.2 代码实现 4 JDK源码解析&#xff08;Runable&#xff09; &#x1f64a; 前言…

【机器学习智能硬件开发全解】(二)—— 政安晨:嵌入式系统基本素养【处理器原理】

嵌入式系统的基本素养包括以下几个方面&#xff1a; 硬件知识&#xff1a;嵌入式系统通常由硬件和软件组成&#xff0c;了解和熟悉硬件的基本知识&#xff0c;包括微处理器、存储器、外设等&#xff0c;并了解它们的工作原理和特性。 软件编程&#xff1a;熟悉至少一种编程语言…

人工智能迷惑行为大赏——需求与科技的较量

目录 前言 一、 机器行为学 二、人工智能迷惑行为的现象 三、产生迷惑行为的技术原因 四、社会影响分析 五、解决措施 总结 前言 随着ChatGPT热度的攀升&#xff0c;越来越多的公司也相继推出了自己的AI大模型&#xff0c;如文心一言、通义千问等。各大应用也开始内置…

WPF图表库LiveCharts的使用

这个LiveCharts非常考究版本&#xff0c;它有非常多个版本&#xff0c;.net6对应的是LiveChart2 我这里的wpf项目是.net6&#xff0c;所以安装的是这三个&#xff0c;搜索的时候要将按钮“包括愈发行版”打勾 git&#xff1a;https://github.com/beto-rodriguez/LiveCharts2?…

webpack面试题

1、webpack是干什么的 Webpack是一个现代的JavaScript应用程序的静态模块打包工具。当webpack处理应用程序时&#xff0c;它会在内部构建一个依赖图&#xff0c;此依赖图对应映射到项目所需的每个模块&#xff0c;然后将所有这些模块打包成一个或多个bundle。Webpack的主要功能…

趣学前端 | 平平无奇的JavaScript函数

背景 最近睡前习惯翻会书&#xff0c;重温了《JavaScript权威指南》。这本书&#xff0c;文字小&#xff0c;内容多。两年了&#xff0c;我才翻到第十章。因为书太厚&#xff0c;平时都充当电脑支架。 JavaScript函数 读这章之前&#xff0c;我感觉我三十年开发功力&#xf…

经典卷积神经网络LeNet-5、AlexNet、VGG-16

一、LeNet-5 这里只讲一下C5&#xff0c;卷积核大小是5*5&#xff0c;通道数是120&#xff0c;所以卷积完成之后是1*1*120&#xff0c;这里形成120个卷积结果。每个都与上一层的16个图相连。所以共有(5x5x161)x120 48120个参数&#xff0c;同样有48120个连接。 其他卷积层和池…

Maven: There are test failures.(已解决)

问题解决办法 进行package打包时报错如下&#xff1a; 然后这些并不能看出是测试的哪里的问题&#xff0c;可以点击上一级进行查看更详细的错误&#xff0c;越向上日志越详细&#xff0c;可以看到是52行出了错误&#xff0c; 52对应代码如下&#xff1a; 原因是存在注册的测…

HTML5+CSS3+JS小实例:全屏范围滑块

实例:全屏范围滑块 技术栈:HTML+CSS+JS 效果: 源码: 【HTML】 <!DOCTYPE html> <html lang="zh-CN"> <head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale…

R语言系列4——R语言统计分析基础

目录 写在开头1. 描述性统计分析1.1 描述性统计分析的定义与重要性1.2 R语言中的描述性统计分析功能1.3 常用的描述性统计量及其在R中的计算方法1.4 使用R语言进行描述性统计分析的实际示例1.5 描述性统计分析的局限性和应用注意事项 2. 假设检验基础2.1. 假设检验的基本原理和…

机试:偶数分解

题目描述: 代码示例: #include <bits/stdc.h> using namespace std; int main(){ // 算法思想1:遍历小于该偶数的所有素数,存入数组中,遍历数组找出两个数之和等于偶数的数int n;cout << "输入样例" << endl;cin >> n;int nums[n];int k …