首页 > 编程语言 >Educator:C++面向对象-STL实训

Educator:C++面向对象-STL实训

时间:2024-05-24 10:25:12浏览次数:23  
标签:stu1 name STL C++ int Virus score 实训 Gen

第1关:病毒复制


任务描述

本关任务:设计一个病毒类。

相关知识

本关涉及到的内容如下:

  • 拷贝构造函数
  • 重载!===运算符
拷贝构造函数

当一个构造函数的唯一一个参数就是它所在类的引用时,这个构造函数就是一个拷贝构造函数

编程要求

设计一个病毒Virus 类,它的内部有一个Gen变量,代表当前病毒对象的年龄默认值为0

当一个病毒对象通过拷贝构造函数拷贝到一个新的病毒对象时,它就将新对象的的Gen变量设为它的Gen值加1的值。

评测代码会在Begin-End区域创建一些病毒对象,把它们拷贝多份存在数组里,然后会将数组中的元素与一个int整型数据g进行g==virus[i]形式的比较,以找出Gen g 的病毒,并进行 计数

学员还需要添加适当的内容以支持声明对象数组和与一个整型变量进行比较的功能。

 
class Virus
{
/********* Begin *********/
public:
int Gen;
//病毒类的声明
Virus(){Virus(const Virus&v)
{
    Gen=v.Gen+1;
}
Virus(int g)
{
    Gen=Gen+1;
}
friend bool operator==(const int g,const Virus &t1)

    Gen =0;
}
Virus(const Virus&v)
{
    Gen=v.Gen+1;
}
Virus(int g)
{
    Gen=Gen+1;
}
friend bool operator==(const int g,const Virus &t1)

{
    return g==t1.Gen;
}
/********* End *********/
};
 

第2关:动态学生信息管理


任务描述

本关任务:编写一个能动态管理学生信息的程序。

相关知识

本关涉及的内容如下:

  • vector容器的使用
  • 容器的迭代器
  • sort函数的使用
  • find函数的使用
vector容器的使用

vector位于头文件<vector>,是C++提供的一种顺序存储的容器,能通过位置索引高效的访问容器中的任意元素,可以看做是一个长度能动态变化数组

vector类是一个模板类,使用时需要指定模板参数。注意:作为模板参数的类型要有无参数的构造函数(如果不使用Allocator)。

其具体代码如下:
 

#include <iostream>
#include <vector>
#include <string>
#include<stdio.h>
#include <algorithm>
using namespace std;
 
/********* Begin *********/
 
//自定义的类或者其他内容
class student
{
 
public:
    string name;
    int score;
    student(string na = "", int sco = 0) :name(na), score(sco)
    {
 
    }
    bool operator ==(const student& other)const
    {
        return other.name == name;
 
    }
 
};
bool cmp(student  a, student b)
{
    return a.name < b.name;
 
}
/********* End *********/
 
int main()
{
    /********* Begin *********/
    vector<student> stu1;
    int i = 0;
    char m;
    while (scanf("%c", &m) != EOF)
    {
        switch (m)
        {
        case 'A':
        {
 
            string name;
            int score;
 
            cin >> name >> score;
            student stu(name, score);
            if (stu1.empty())
            {
                stu1.push_back(stu);
            }
            else
            {
                auto it = find(stu1.begin(), stu1.end(), name);
                if (it != stu1.end())
                {
                    it->score = score;
                    break;
                }
                else
                {
                    stu1.push_back(stu);
                }
 
            }
 
            /* for (auto it = stu1.begin(); it != stu1.end(); it++)
             {
                 if (it->name == name)
                 {
                     it->score = score;
                     flag = 1;
                 }
             }
             if (flag == 1)
             {
             }
             else
             {
                stu1.push_back(stu);
             }*/
 
        }break;
        case 'P':
        {
            if (stu1.empty())
            {
                cout << "[空]" << endl;
            }
            else
 
            {
                for (auto it = stu1.begin(); it != stu1.end(); it++)
                {
                    cout << it->name << " " << it->score << endl;
                }
 
            }
        }break;
        case 'R':
        {
            string name;
            cin >> name;
            auto it = find(stu1.begin(), stu1.end(), name);
            if (it!=stu1.end())
            {
                stu1.erase(it);
            }
 
 
        }break;
        case 'S':
        {
            sort(stu1.begin(), stu1.end(), cmp);
 
        }break;
        }
    }
    /********* End *********/
}
 

第3关:还原键盘输入


任务描述

本关任务:编写一个能根据键盘操作记录还原实际输入的小程序。

相关知识

本关涉及到的内容如下:

  • list容器的使用
list容器的使用

list位于头文件<list>,是 STL 提供的一种顺序存储的容器,它不支持通过位置索引访问,但能高效的进行插入、删除元素操作,通常由双向链表实现。

list是一个模板类,使用时需要指定模板参数,而且作为参数的类型需要有无参数的构造函数(如果不使用Allocator)。

#include <iostream>
#include <string>
#include <list>
using namespace std;
 
int main()
{
    /********* Begin *********/
    //读取输入,解析并输出复原后的输出
    string s;
    list<char>l;
    list<char>::iterator it=l.begin();
    while(cin>>s){
        int i=0;
        while(i<s.size()+1){
            if(s[i]=='\0'){
                it=l.begin();
                while(it!=l.end()){cout<<*it;it++;}
                cout<<endl;
                l.clear();
                it=l.begin();
            }
            if(s[i]>='A'&&s[i]<='Z'||s[i]>='a'&&s[i]<='z'||s[i]>='0'&&s[i]<='9')
                l.insert(it,s[i]);
                    //**!为何迭代器it不用it++,不然不就一直指向l.begin()了吗?!**//
            else if(s[i]=='>')it++;
            else if(s[i]=='<')it--;
            else if(s[i]=='[')it=l.begin();
            else if(s[i]==']')it=l.end();
 
            i++;
        }
    }
    
    
    /********* End *********/
}

标签:stu1,name,STL,C++,int,Virus,score,实训,Gen
From: https://blog.csdn.net/iceslime/article/details/139065840

相关文章

  • 浅谈C++函数
    目录一、函数的概念二、调用函数的两个前提三、函数传参的三种形式四、函数返回类型一、函数的概念函数是C++程序的基本模块,通常一个C++程序由一个或多个函数组成。函数可以完成用户指定的任务,一般分为库函数和用户自定义的函数。函数由函数头和函数体组成,函数头中包......
  • 【C++】两个类的相互引用_c++ 类相互引用
    有时候在设计数据结构的时候,可能会遇到两个类需要相互引用的情形。比如类A有类型为B的成员,而类B又有类型为A的成员。那么这种情形下,两个类的设计上需要注意什么呢?同一文件尝试方案将A和B的定义都放在一个文件中,例如:#include<iostream>classA{public:......
  • 套利(spfa判环+STL)
    套利题目描述套利是利用汇率差异实现货币增值。例如,1美元可以兑换0.5英镑、1英镑可以兑换10法郎、1法郎可以兑换0.21美元。接下来,一个聪明的交易商就可以从1美元开始,0.5*10.0*0.21=1.05美元,获得了5%的利润。你的任务是写一个程序,从输入文件读入汇率清单,然后决定套利......
  • C++Linux系统编程——文件和目录操作函数
    stat函数(重要)#include<sys/types.h>#include<sys/stat.h>#include<unistd.h>​intstat(constchar*path,structstat*buf);intlstat(constchar*pathname,structstat*buf);功能: 获取文件状态信息 stat和lstat的区别:   当文件是一个符号......
  • 【C++初阶】—— 类和对象 (上)
    ......
  • C++基础知识学习笔记(2)
    资料来源https://www.bilibili.com/video/BV1et411b73Z/?spm_id_from=333.337.search-card.all.click&vd_source=cc561849591f6a210152150b2493f6f3简单知识点指针作用:通过指针间接访问内存可以通过指针来保存一个地址。指针所占内存空间32位操作系统,占4个字节。64位操......
  • 深入理解C++多态-虚函数
    引言C++多态的实现方式可以分为静态多态和动态多态,其中静态多态主要有函数重装和模板两种方式,动态多态就是虚函数。下面我们将通过解答以下几个问题的方式来深入理解虚函数的原理:为什么要引入虚函数?(用来解决什么问题)虚函数底层实现原理使用虚函数时需要注意什么?正文......
  • 在C++中,将类的成员函数(也称为方法)作为参数传递
    在C++中,你可以将类的成员函数(也称为方法)作为参数传递,但这通常涉及到使用函数指针或者更现代的C++11及以后版本的std::function和lambda表达式。不过,更常见的是传递成员函数指针,但请注意,成员函数指针与常规函数指针在语法和使用上有所不同,因为成员函数需要访问类的特定实例(即对象)。......
  • 单例模式c++实现
    单例模式是一种创建型设计模式,它保证一个类仅有一个实例,并提供一个全局访问点来访问这个唯一实例。下面是一个简单的C++实现单例模式的例子:cppincludeincludeclassSingleton{private:staticSingleton*instance;staticstd::mutexmtx;Singleton(){}//私有构造函......
  • c++ 语法 引用
      引用变量是一个别名,也就是说,它是某个已存在变量的另一个名字。一旦把引用初始化为某个变量,就可以使用该引用名称或变量名称来指向变量。C++引用vs指针引用很容易与指针混淆,它们之间有三个主要的不同:不存在空引用。引用必须连接到一块合法的内存。一旦引用被初始化为......