草庐IT

stl-algorithm

全部标签

c++ - 如何使用STL实现LFU缓存?

我正在尝试使用纯STL实现LFU(最不常用)缓存(我不想使用Boost!)。要求是:使用Key关联访问任何元素,例如std::map。能够释放优先级最低的项目(使用其UsesCount属性)。能够更新任何项目的优先级(UsesCount)。问题是:如果我使用std::vector作为项目的容器(Key、Value、UsesCount),std::map作为vector的迭代器容器用于关联访问和std::make_heap、std::push_heap和std::pop_heap作为vector内的优先级队列实现,map中的迭代器在堆操作后无效。如果我在之前的配置中使用std::list

c++ - 字符串匹配 : Computing the longest prefix suffix array in kmp algorithm

KMPalgorithmforstringmatching.以下是code我在网上找到了计算最长前缀-后缀数组的方法:定义:lps[i]=thelongestproperprefixofpat[0..i]whichisalsoasuffixofpat[0..i].代码:voidcomputeLPSArray(char*pat,intM,int*lps){intlen=0;//lengthofthepreviouslongestprefixsuffixinti;lps[0]=0;//lps[0]isalways0i=1;//theloopcalculateslps[i]fori=1toM

c++ - 从 DLL 导出 STL std::basic_string 模板时,出现 LNK2005 错误

好的,所以我已经阅读了几个关于这个主题的问题和文章,我觉得我了解基础知识,但我仍然遇到问题。我有一个DLL,它导出一个以std::string作为成员的类。我的主程序包含也有字符串的类,并且它使用DLL。如果我在VS2010中编译DLL,我会收到以下警告:warningC4251:'MyClass::data':class'std::basic_string'needstohavedll-interfacetobeusedbyclientsofclass'MyClass'当我编译EXE时,我得到了相同的警告,但没有错误,程序编译并运行。事实上,这是一个大项目,所以我收到了40条警告,我

c++ - 如何调试 STL/C++ 的 GCC/LD 链接过程

我正在使用C++开发裸机cortex-M3,以获取乐趣和利润。我使用STL库是因为我需要一些容器。我认为通过简单地提供我的分配器它不会向最终的二进制文件添加太多代码,因为你只得到你使用的东西。实际上我什至没想到有任何与STL的链接过程(给我的分配器),因为我认为这都是模板代码。顺便说一下,我正在使用-fno-exception进行编译。不幸的是,我的二进制文件中添加了大约600KB或更多。我用nm查看了最终二进制文件中包含的符号,这对我来说似乎是个笑话。列表太长了,我不会尝试跳过它。虽然有一些弱符号。我还查看了链接器生成的.map文件,我什至找到了scanf符号.text0x00015

OpenCV #以图搜图:感知哈希算法(Perceptual hash algorithm)的原理与实验

1.介绍感知哈希算法(PerceptualHashAlgorithm,简称pHash)是哈希算法的一种,主要用来做相似图片的搜索工作。 2.原理感知哈希算法(pHash)首先将原图像缩小成一个固定大小的像素图像,然后将图像转换为灰度图像,通过使用离散余弦变换(DCT)来获取频域信息。然后,根据DCT系数的均值生成一组哈希值。最后,利用两组图像的哈希值的汉明距离来评估图像的相似度。魔法:概括地讲,感知哈希算法一共可细分八步:缩小图像:将目标图像缩小为一个固定的大小,通常为32x32像素。作用是去除各种图像尺寸和图像比例的差异,只保留结构、明暗等基本信息,目的是确保图像的一致性,降低计算的复杂度。

c++ - 如何从传递给某些 STL 算法的谓词中获取元素索引?

比如说,我有元素vector和一个掩码数组,我想从vector中提取具有真实相应掩码值的元素以分离vector。有没有办法为此目的使用std::copy_if?问题是,我只有谓词内部元素的值,没有迭代器,所以我不知道地址掩码数组的实际索引。我可以像这样直接操作地址:vectormask;vectora,b;copy_if(a.begin(),a.end(),b.begin(),[&](intx)->bool{size_tindex=&x-&a[0];//Ugly...returnmask[index];});但是,我发现这是一个丑陋的解决方案。有更好的想法吗?更新:另一种可能的解决方案

Couldn‘t agree a key exchange algorithm(available:curve25519-sha256,curve25519-sha256@libssh.org解决方案

  大家好,我是爱编程的喵喵。双985硕士毕业,现担任全栈工程师一职,热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。喜欢通过博客创作的方式对所学的知识进行总结与归纳,不仅形成深入且独到的理解,而且能够帮助新手快速入门。  本文主要介绍了Couldn’tagreeakeyexchangealgorithm(available:curve25519-sha256,curve25519-sha256@libssh.org解决方案,希望能对使用winscp的同学们有所帮助。文

c++ - 为什么C++ STL map容器的复杂度是O(log(n))?

对于vector和list等C++STL容器,查找元素并插入或删除它们的复杂性是不言自明的。然而,对于map容器,尽管我从阅读中知道访问和插入复杂度/性能是O(log(n)),但我无法弄清楚为什么。显然,我对map的理解程度还不够,因此非常感谢对这个主题的一些启发。 最佳答案 映射或集合的元素包含在树结构中;每次检查树的节点时,您都​​会确定要查找/插入的元素是小于还是大于该节点。您需要执行此操作的次数(对于适当平衡的树)是log2(N),因为每次比较都会排除一半的可能性。 关于c++-

c++ - 为什么在 STL 中允许未定义的行为?

默认情况下,std::stack的“底层容器”是std::deque。因此,对于std::deque而言,任何未定义的行为对于std::stack而言都是未定义的行为。cppreference和其他站点在描述成员函数的行为时使用术语“有效地”。我认为这意味着它适用于所有意图和目的。因此,调用top()和pop()等同于调用back()和pop_back(),并在空容器上调用这些是未定义的行为。根据我的理解,它是未定义行为的原因是为了保留不抛出保证。我的理由是std::vector的operator[]具有不抛出保证,如果容器大小大于N,则为未定义行为,但at()有很强的保证,如果n超出

c++ - 为什么我可以在不包含 STL 的情况下使用 nullptr?

C++nullptr是std::nullptr_t类型。为什么像这样的程序intmain(){int*ptr=nullptr;}仍然有效,尽管它不包含任何STL库? 最佳答案 在C++11中,他们想添加一个关键字来替换宏NULL(基本上定义为#defineNULL0),因为它是一个核心概念,并且由于一些恼人的错误,当您被迫使用0作为您的空指针常量时,您会遇到一些恼人的错误。建议的关键字数量。搜索大型代码库以确保关键字未被使用,并且它仍然描述了他们想要的内容(空指针常量)。nullptr被发现足够罕见且足够令人回味。默认情况下,nul