草庐IT

feature_map

全部标签

c++ - 在 map 上使用 find_if 按值查找

我有一个有map的类(class)。我需要通过搜索特定值而不是键来在map中找到迭代器。使用成员函数谓词IsValueFound,正在尝试这个。classA{public:voidfindVal();private:intstate;mapexmap;boolIsValueFound(pairitr){returnstate==itr.second;}};voidA::findVal{itr=find_if(exmap.begin,exmap.end,mem_fun1_ref(&A::IsValueFound));}我遇到编译错误。我不确定这些函数适配器的语法是什么。请帮忙。编辑:抱歉

计算机视觉算法——BEV Perception算法总结(3D LaneNet / LSS / PON / BEVFormer / GKT / Translating Image to Maps)

计算机视觉算法——BEVPerception算法总结(3DLaneNet/LSS/PON/BEVFormer/GKT/TranslatingImagetoMaps)计算机视觉算法——BEVPerception算法总结(3DLaneNet/LSS/PON/BEVFormer/GKT/TranslatingImagetoMaps)1.HomographBased——3DLaneNet2.DepthBased——LSS3.MLPBased——PON4.TransformerBased——BEVFormer5.TransformerBased——GTK6.TransformerBased——Trans

C++ 使用 std::map 计算实例/直方图

我见过类似下面的示例代码:std::strings="HelloWorld!";std::maph;for(std::string::const_iteratori=s.cbegin();i!=s.cend();++i){++h[*i];}assert(h['l']==3);这似乎依赖于在每个字母第一次出现时将值类型归零。即使使用像std::size_t这样没有默认构造函数将其重置为零的东西,也能保证这一点吗? 最佳答案 事实上,这就是map的工作原理:[]运算符正在发生变化,如果映射类型的对象不存在,它将创建然而。由于size_t

c++ - 两个相同的unordered_maps的顺序是否相同?

换句话说,如果我填充两个unordered_map或unordered_set,对象具有完全相同的内容和相同的散列函数,将迭代它们给出相同的序列键/值对?如果是这样,那么它成立的条件是什么(例如,相同的散列函数、相同的键,不一定是相同的值)。 最佳答案 没有。例如,没有要求以任何特定顺序放置具有相同散列的对象。事实上,一般来说,无序映射不可能做到这一点,因为它唯一可以访问的信息是哈希值。 关于c++-两个相同的unordered_maps的顺序是否相同?,我们在StackOverflow

c++ - 如何处理带有指针的 map ?

假设我有一个名为People的类。我在map中存储指向这些人的指针mapmyMap;要创建新人,我使用maps[]运算符。myMap["dave"]->sayHello();但这给了我一个段错误,它甚至没有调用People类的构造函数。我也试过myMap.insert(std::make_pair("dave",newPeople()));但这并没有改变任何东西,构造函数仍然没有被调用,并且程序因段错误而关闭处理这段代码。如何访问和操作其中包含指针的map?为什么上面的方法不起作用,我没有收到编译时错误或警告。非常感谢任何见解,谢谢 最佳答案

c++ - 如何更改要反转的 std::map 的顺序?

有谁知道有什么方法可以将map顺序从“少”改为“多”吗?例如:有一个map称为test.我向其中插入一些条目:test["b"]=1;test["a"]=3;test["c"]=2;在map内部,顺序为(a,3)(b,1)(c,2).我希望它是(c,2)(b,1)(a,3).我怎样才能轻松做到这一点? 最佳答案 通过使用std::greater而不是std::less作为您的key。例如std::map>my_map;参见thereference 关于c++-如何更改要反转的std::m

以非专用模板作为值的 C++ hash_map

我想要一个std::hash_map将(例如)常规std:string映射到多个不同的特化另一个模板类。这个例子是我想要实现的(虽然它是错误的并且无法编译):templateclassFoo{public:Foo(T_value){this->value=_value;}private:Tvalue;};intmain(){hash_mapvarious_foos;various_foos["foo"]=Foo(17);various_foos["bar"]=Foo(17.4);} 最佳答案 map只能存储单一的值类型,所以不能直接

c++ - std::map - 如何更改键排序?

我对std::map有疑问。我用它来映射特定索引下的一些对列表:map>>List;Dijkstra算法中使用了它。主要问题是map按字母顺序对string键进行排序,如下所示:AAA,AA0,AA1,AAB,AC1=AA0->AA1->AAA->AAB->AC1但我想用不同的方式对它进行排序:AAA,AA0,AA1,AAB,AC1=AAA->AAB->AA0->AA1->AC1有什么解决办法吗?我读到过自己制作比较类,但我不知道该怎么做。还是有其他方法可以解决? 最佳答案 您必须提供自己的比较仿函数,它必须在实例化map时作为第三

c++ - 当存在 std::map 时,将代码语句作为参数的宏失败

我在代码语句周围使用了一个宏,以引入嵌套异常处理:#defineTRAP_EXCEPTION(statement)\try\{\try{statement}\catch(Engine::Exception&e)\{\throwMyException(e.message());\}\}在一个案例引发编译器错误之前,它一直运行良好。我设法构建了一个最小的例子:TRAP_EXCEPTION(std::mapMap;)catch(MyException&e){}这会产生以下错误...我该如何修复它(最好是在宏中)?>errorC2143:syntaxerror:missing'>'before

c++ - 通过 emplace() 将对象指针插入到 map 的 map 中不起作用

我正在尝试将指针对象插入到map通过emplace()但它不起作用。我在下面创建了一个简单的问题表示。我正在尝试插入newFooList指针对象类型Foo*.我似乎找不到为FooMap*创建类型的方法在std::mapm_fooMapList.应该用new来完成吗?在map的第二个区域?#include#include#include#include#includeclassFoo{private:intm_foobar;public:Foo(intvalue){m_foobar=value;}voidsetfoobar(intvalue);intgetfoobar();};class