[头歌]第1关:动态学生信息管理

题目: 

C++ 面向对象 _ STL 的应用 (educoder.net)

[头歌]第1关:动态学生信息管理_第1张图片

 [头歌]第1关:动态学生信息管理_第2张图片

[头歌]第1关:动态学生信息管理_第3张图片 考点:

1.自定义排序 bool cmp

2.如何使用find和erase来找到学生类里面的指定姓名的人并将其从动态数组中删除。

3.find要找的是学生类里面的成员变量而非单纯的直接找值,应如何实现 (与自定义排序有相似之处)。

查找学生类中姓名的实现:

find_if实现:

 auto it = find_if(stu.begin(), stu.end(), [na](const student& s) {return s.name == na; })。

其中[targetName](const Student& s) { return s.name == targetName; });是什么作用?

 

这是一个lambda表达式,用于作为`std::find_if`函数的第三个参数,即谓词(Predicate)。谓词是一个可调用对象,它接受一个参数并返回一个bool值,用于指示该参数是否满足某个条件。`std::find_if`函数会在指定的范围内查找第一个使谓词返回true的元素,并返回指向该元素的迭代器。如果没有找到,则返回`last`迭代器。

在这个示例中,我们的lambda表达式接受一个`const Student&`类型的参数`s`,并返回`s.name == targetName`的比较结果,即判断该学生的姓名是否等于目标姓名`targetName`。这个lambda表达式的作用是用于在`stu`容器中查找名字为`targetName`的学生。

如果找到了符合条件的学生,则将其从容器中删除;如果未找到,则输出未找到的消息。最后,我们打印出剩余的学生信息。

#include 
#include 
#include 
#include 
using namespace std;

/********* Begin *********/
//自定义的类和者其他内容
class student
{
    public:
    string name;
    int score;
};

vectorstu;

void print(vector&stu)
{
    if(stu.empty()){cout<<"[空]"<::iterator it=stu.begin();it!=stu.end();it++)
        cout<name<<" "<score<stu2.score;}

void Sort(vector&stu){sort(stu.begin(),stu.end(),cmp);}
/********* End *********/

int main()
{
    /********* Begin *********/
    //读取输入数据,执行动作
    char c;
    string na;int sc;
    while(cin>>c)
    {
        if(c=='A')
        { student t;cin>>na>>sc;
        auto it=
        find_if(stu.begin(),stu.end(),[na](const student&s){return s.name==na;});
        if(it==stu.end()) {t.name=na;t.score=sc;stu.push_back(t);}
        else it->score=sc;
        }
        if(c=='R')
        {cin>>na;
        auto it=
        find_if(stu.begin(),stu.end(),[na](const student& s){return s.name==na;});
        if(it!=stu.end())stu.erase(it);
        }
        if(c=='P'){print(stu);}
        if(c=='S'){Sort(stu);}
    }
    
    
    /********* End *********/
}

你可能感兴趣的:(头歌,STL,自定义排序,数据结构)