首页 > 解决方案 > 寻找部分代码的解释

问题描述

我有这个功能,一个由 id 代表的学生将在特定学期添加一门课程。这段代码是正确的,但我不明白他做的那部分
for (size_t i = 0; i < (*iteratorVectorP).size(); i++) ...

void add_course(map<int, map<int, vector<course *> * > > &DB, int 
     semester, int id, course c)
{
    auto iterator = DB.find(id);    //find id as key, set map to value
    vector<course*> *pointer = new vector<course*>;
    if (iterator != DB.end())
    {
        auto iterator1 = ((*iterator).second).find(semester);   //find                 
        semester as key, set vector to value
        if (iterator1 == (*iterator).second.end())      //if semester does not exist
        {
            pointer->push_back(new course(c));
            (iterator->second)[semester] = pointer;
        }
        else        //if semester exist
        {
            auto iteratorVectorP = (iterator->second)[semester];
            // i do not understand what his doing here 
            for (size_t i = 0; i < (*iteratorVectorP).size(); i++)
            {
                if (c == *(*iteratorVectorP)[i])
                {
                    return;     //exit when class exist
                }
                else
                {
                    (*iteratorVectorP).push_back(new course(c));
                    return;
                }
            }
        }
    }
}

标签: c++

解决方案


看起来 iteratorVectorP 是一个指针,所以调用 (*iteratorVectorP).size() 将得到它指向的值。


推荐阅读