草庐IT

c++ - 带有 if 语句的 auto 函数不会返回值

我制作了一个模板和一个auto函数,用于比较2个值并返回最小值。这是我的代码:#includeusingnamespacestd;//Templatewithavaluereturningfunction:PrintSmallertemplateautoPrintSmaller(TNumOne,UNumTwo){if(NumOne>NumTwo){returnNumTwo;}else{returnNumOne;}}intmain(){intiA=345;floatfB=23.4243;cout但它无法编译,我在VS2015上遇到此错误:错误C3487“int”:所有返回表达式必须推导出

c++ - 检测类型是否为 "mapping"

我想使用它们的::iterator成员类型将C++容器解析为另一个对象。迭代器成员类型指向单一类型(vector、队列等)的对象的容器将变成类列表对象,迭代器成员类型的容器指向一个std::pair将变成一个类似map的对象。我正在尝试编写一个成员函数来检测后一种容器,但它不起作用。这是我到目前为止所拥有的:#include#include#includetemplatestructis_pair:std::false_type{};templatestructis_pair>:std::true_type{};templateconstexprboolis_pair_v=is_pai

c++ - 为什么这个涉及 std::enable_if 的模板元函数会产生不希望的结果?

我有一个类型特征templatestructis_binary_function:std::false_type{};及其专长templatestructis_binary_function&&!std::is_void_v&&!std::is_void_v&&function_t::isBinaryCallable,function_t>>:std::true_type{};我正在尝试识别具有公共(public)类型定义result_t、parameter1_t和parameter2_t以及静态常量的类isBinaryCallable值为true。然而,下面的代码没有输出我所期望的:

c++ - vector 和 map 抛出异常

我的任务是输出所有十位数字,其中数字不重复。我首先使用的是这样的东西:#include#include#include#include#includeusingnamespacestd;voidTask5(){autoinitialization=[](map*m,intcount){for(inti=0;i*m,intcount,intvalue){for(inti=9;i>count;--i)m[count][i][value]=false;};/*Forcreatecopymap*/automould=[](map*m,map*m_copy,intcount)->map*{if(

c++ - 这段代码是否滥用了 STL 的 find_if?

假设我有一个存储在vector中的服务器名称列表,我想一次联系一个服务器,直到有人成功响应为止。我正在考虑以下列方式使用STL的find_if算法:find_if(serverNames.begin(),serverNames.end(),ContactServer());其中ContactServer是一个谓词函数对象。一方面,存在一个问题,因为谓词不会总是为相同的服务器名称返回相同的结果(因为服务器停机、网络问题等)。但是,无论使用谓词的哪个拷贝(即谓词没有真实状态),都会返回相同的结果,因此状态保持谓词的原始问题在这种情况下不相关。你说呢? 最佳答案

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++ - 使 std::map key const 有意义吗?

这个问题在这里已经有了答案:Whatisdifferencebetweenconstandnonconstkey?(7个答案)关闭9年前。定义std::map时,将键类型设置为const是否有意义?

C++ std::map,键的旋转

我需要在map中实现类似“第一键轮换”的功能。对问题的更详细的解释。有一张map:std::maptest;插入了以下元素:test[0.5]=15;test[1]=20;test[2.3]=12;test[3.7]=18旋转算法可以重写为:a]记住map中的第一个元素(key最低的元素):rem_el=map[0]//记法b]从map中删除第一个元素c]为map中所有剩余元素设置新键:map[i].key=map[i].key-rem_el.keyd]使用新键将记住的键添加到map:最后一个键和记住的键的总和test[rem_el.key+test[n-1].key]=rem_el.

c++ - 从 map 容器中查找第一个大于用户指定值的值

我有一个map容器。如何使用find_if返回第一个大于用户指定搜索值的值,如下所示:std::map::iteratorit=find_if(Mymap.begin(),Mymap.end(),......非常感谢! 最佳答案 您确定要通过容器对任何值大于您的条件的项目进行线性搜索吗?最好还保留一个可以调用upper_bound的排序值的单独索引,以对数时间执行而不是元素数量的线性执行。或者查看boost::multi_index。 关于c++-从map容器中查找第一个大于用户指定值的

c++ - 错误 : no match for ‘operator<’ in ‘__x < __y’ when trying to insert in two map

在代码中有两个映射。一个存储对和另一个存储,其中值是具有5个变量的类,数据类型为字符串、整数、字符串、整数、整数。但是在插入第二个映射期间,我收到错误g++错误:尝试在map中插入时,'__x如何解决。classValues{private:std::stringC_addr;intC_port;std::stringS_addr;intS_port;intC_ID;public:Values(std::string,int,std::string,int,int);voidprintValues();};Values::Values(std::stringCaddr,intCport