草庐IT

hash_element

全部标签

c++ - 出于性能原因替代 stdext::hash_map

我正在开发一个高性能应用程序,其中所有调用都必须合理。我有一张map,在每次交易开始时使用一次来进行我想改进的查找。map在启动时加载,之后不会改变。下面映射中的键是一个std::string但如果需要它可以更改为char数组。C或C++作为解决方案很好。typedefstdext::hash_mapsymbols_t;有没有人知道任何其他可以消除查找或更快的解决方案?提前感谢您的帮助。来自编辑的附加信息:1.hash_map目前有35万个元素。2.每个键值的长度通常在4到10个字符之间。3.从第三方API接收回调信息。回调被赋予一个符号,在进行map查找时用作键值。软件的其余部分由m

c++ - 错误 "An array may not have elements of this type"

由于这个奇怪的编译错误,我在编译我的程序时遇到了问题...这是代码的具体部分://theerroroccuresat"char_adr[][]"intheconstructorparametersAddresses(string_ime,string_egn,char*_adres,char_adr[][],intadrLen):Person(_ime,_egn,_adres){addressLength=0;for(;addressLength=5){break;}adr[addressLength]=_adr[addressLength];}} 最佳答案

以非专用模板作为值的 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++ STL : Why is there no upper_bound equivalent that retrieves the greatest element smaller then a specific key?

通常,STL是为提高速度而构建的。然而,在map和set数据结构上只有upper_bound和lower_bound并且没有操作来检索具有小于输入键的最大键的条目k.为什么是这样?我知道我可以简单地做一个lower_bound并做一个--it检索它,但根据数据结构,立即搜索正确的条目可能比搜索另一个条目然后返回一步更有效。例如,std::map使用红黑树,即二叉搜索树。如果upper_bound返回的元素是大于根的最小元素,则--it必须回到根,查询O(logn)的额外成本。如果这是Java,我会接受设计决定。然而,STL是为实现最高速度而构建的,那么为什么要省略此操作?澄清:我不是在

c++ - 获取 std::min_element 和 std::max_element 以将迭代器返回到最后一个值?

当使用std::min_element和std::max_element时,如果范围内有多个元素是最低/最高,则返回的迭代器指向第一个这样的元素。但是我需要它指向最后一个这样的元素。在不编写自己的函数或反转输入数据结构的情况下,我该怎么做?我的输入数据结构是一个C风格的数组,例如intdata[N]并且C++11或Boost不可用(不是我的选择..) 最佳答案 你不必自己写数据结构,你可以使用std::reverse_iterator:typedefstd::reverse_iteratorRev;std::size_tidx=Re

Vue + Element UI el-table + sortablejs 行、列拖拽排序

实现ElementUI中的el-table表格组件的行和列的拖拽排序使用Vue3+ElementPlusUI+sortablejs安装sortablejspnpminstallsortablejs行拖拽基本实现效果scriptsetup>import{onMounted,ref}from"vue";importSortablefrom"sortablejs";consttableData=ref([{id:1,date:"2016-05-02",name:"王小虎111",age:21,address:"上海市普陀区金沙江路1518弄",},{id:2,date:"2016-05-04",na

c++ - std::max_element 跳过 NAN

我有一个std::vector可能包含多个NAN值。我想找到vector中最大的元素。我怎样才能有效地跳过NAN在比较中?我想避免调用isnan在每个元素上。有什么想法吗?//std::max_element([NAN,NAN,NAN,-31,-89])=NAN//becauseNAN>-31returnsNAN.//howcanIskipallNANsinthecomparison?//test2belowismyusecase.#include#include#includevoidvector_max(std::vectorv,double&max,int&imax){std::

【C++修行之道】竞赛常用库函数(sort,min和max函数,min_element和max_element、nth_element)

目录一、sort1.1sort简介语法参数功能适用容器1.2sort的用法1.3自定义比较函数 示例1265蓝桥题——排序二、min和max函数三、min_element和max_element 497蓝桥题——成绩分析四、nth_element一、sort1.1sort简介sort函数包含在头文件中。在使用前需要#include或使用万能头文件。sort是C++标准库中的一个函数模板,用于对指定范围内的元素进行排序。sort算法使用的是快速排序(QuickSort)或者类似快速排序的改进算法,具有较好的平均时间复杂度,一般为O(nlogn)语法Sort(start,end,cmp)参数(1)

c++ - 字符串的双向 "Hashing"

我想从字符串生成int并能够生成它。类似于散列函数但双向函数。我想在我的应用程序中使用整数作为ID,但希望能够在记录或调试时将其转换回来。喜欢:intid=IDProvider::getHash("NameOfMyObject");object*a=createObject(id);...if(error){LOG(IDProvider::getOriginalString(a->getId()),"somemessage");}我听说过稍微修改过的CRC32可以快速且100%可逆,但我找不到它,我自己也写不出来。任何提示我应该使用什么?谢谢!编辑我刚刚找到了来源,我从以下位置获得了整

c++ - 我可以使用成员变量作为 hash_set/hash_map 的键吗?

我有这样一个类:classFoo{longlongId;stringx;stringy;//othermembervariablesandfunctions};我想将其存储在hash_set中(或hash_map),但使用Id成员变量作为插入和搜索的键。我不确定我该怎么做。我想到了以下几种方法,但都不是很好:1)我可以编写一个自定义散列函数,使用Id对对象进行散列,但我不能使用find()hash_set上的方法通过Id(longlong)查找项目,因为它需要Foo要传入的对象。2)我可以复制Id并创建一个hash_map而不是hash_set但我有1亿个这些对象的实例,所以我不想复制