RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 831244
Accepted
Johnny Rage
Johnny Rage
Asked:2020-05-21 23:27:34 +0000 UTC2020-05-21 23:27:34 +0000 UTC 2020-05-21 23:27:34 +0000 UTC

与向量中的迭代器相关的错误

  • 772

根据作业,你需要编写一个mset类来执行set类的主要功能,但是通过vector类。同时,mset 类(需要编写的类)必须是模板,而不是绑定到特定的数据类型。我声明了一个迭代器,并在构造函数中尝试将其重置为向量的开头。此行给出以下错误:

错误 3 错误 C4430:缺少类型说明符 - 预期为 int。笔记。C++ 默认不支持 int

错误 5 错误 C2146:语法错误:缺少“;” 在 id "vj" 之前

问题:可能是什么问题?

问题#2:我该如何解决这个问题?

问题#3:这个错误的机制是什么?

我不会丢掉主要代码,因为只有对默认构造函数的调用、添加元素的方法调用和打印集合的调用。

编码:

            #pragma once
            #include <vector>
            #include <iostream>
            #include <iomanip>
            using namespace std;
            template <typename tname>
            class mset
            {
            public:

                vector<tname> vecSet;
                vector<tname>::iterator vi;
                vector<tname>::iterator vj;
                mset()
                {
                    vecSet.reserve(1);
                    vecSet[0] = 0;
                    vi = vecSet.begin();
                    vj = vecSet.begin();
                }

                void Add(tname value)//добавление элемента в вектор
                {
                    vecSet.push_back(value);
                    sort();
                }
                void Rm(int index)//уничтожение элемента
                {
                        vi = index;
                        vecSet.erase(vi);
                        sort();
                }
                bool RmDb() // уничтожение дубликатов
                {
                    sort();
                    for (vi = vecSet.begin(); vi != vecSet.size(); vi + 1)
                    {
                        if (vecSet[vi] == vecSet[vi + 1])
                        {
                            vecSet.erase(vi);
                        }
                    }

                }
                tname TakeValue(int i)//взятие значения по индексу
                {
                    vi = vecSet.begin();
                    return vecSet[vi+i];
                }
                void sort()//сортировка
                {
                    for (vi = vecSet.begin(); vi != vecSet.size(); vi + 1)
                    {
                        for (vj = vecSet.begin(); vj != vecSet.size() - 1; j + 1)
                        {
                            if (vecSet[vj + 1] < vecSet[vj]) swap(vecSet[vj + 1], vecSet[vj]);
                        }
                    }
                }
                void Print()
                {
                    for (vi = vecSet.begin(); vi != vecSet.size(); vi+1)
                    {
                        cout << setw(1) << vecSet[vi];
                    }
                    cout << endl;
                }
                ~mset()
                {
                }
            private:
            //  vector<tname>::iterator vecIt = 0;
            };
c++
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    Ariox
    2020-05-22T05:40:59Z2020-05-22T05:40:59Z

    虽然这不是问题的答案,但我仍然会写:

    你想要做的事情叫做flat_set. 例如,您可以采用boost::flat_set. 如果您想获得与功能相似的东西std::set-采用其界面而不是完全从头开始发明自行车是合乎逻辑的。该界面可以在这里查看。您可以将typename std::vector<T>::iteratorand保留为迭代器类型typename std::vector<T>::const_iterator- 在这种情况下,创建自己的迭代器确实没有意义,排序向量的迭代器完全符合迭代器的要求std::set

    实际上flat_set,它只是一个已排序的向量。但这并不意味着每次插入时都需要对其进行排序!找到一个可以插入元素的地方就足够了,为此在标准库lower_bound和upper_bound. 如果你不想使用标准的,实现你自己的版本,它不会改变本质。那些。您只需要找到插入点upper_bound并插入带有重载的元素std::vector::insert(iterator_type it, value_type v)

    为什么您需要对该方法进行专业化?在同一个地方,模板方法(如果有的话)被简化为调用类似的方法std::vector。如果您需要外部函数的重载,请编写类似

    template<class T> bool operator = (const mset<T>& lha, const mset<T>& rha) noexcept{
      return ...;
    }
    
    • 0

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    是否可以在 C++ 中继承类 <---> 结构?

    • 2 个回答
  • Marko Smith

    这种神经网络架构适合文本分类吗?

    • 1 个回答
  • Marko Smith

    为什么分配的工作方式不同?

    • 3 个回答
  • Marko Smith

    控制台中的光标坐标

    • 1 个回答
  • Marko Smith

    如何在 C++ 中删除类的实例?

    • 4 个回答
  • Marko Smith

    点是否属于线段的问题

    • 2 个回答
  • Marko Smith

    json结构错误

    • 1 个回答
  • Marko Smith

    ServiceWorker 中的“获取”事件

    • 1 个回答
  • Marko Smith

    c ++控制台应用程序exe文件[重复]

    • 1 个回答
  • Marko Smith

    按多列从sql表中选择

    • 1 个回答
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Suvitruf - Andrei Apanasik 什么是空? 2020-08-21 01:48:09 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5