草庐IT

algorithm

全部标签

c++ - 给定范围内的完美正方形 : abnormal execution of loops

程序编号1:在给定的a和b范围内,其中ab,我想找出一个数字是否是一个完美正方形,如果是,则打印其根。因此,我编写了如下代码:#include#include#include#includeusingnamespacestd;floatsquaredroot(intn){floatlow=0.0,mid;floathigh=(float)n+1;while((high-low)>0.00001){mid=(low+high)/2;if(mid*mid>a>>b;floatroo=0.0;for(i=a;i对于给定的输入15,输出应该是2。但是,上面的程序没有打印任何值。然而,当我尝试使

c++ - 将元素插入排序数组并找到其索引的最有效方法

我需要将一个元素插入排序范围,但我还需要知道它的索引(范围内小于该元素的元素数)。我想在O(logN)时间内完成此操作。我可以使用基本的C++容器执行此操作吗?我想使用std::multimap,有了这个容器,我可以将元素插入到它的位置,复杂度为O(logN)。但是要获取索引,我需要调用std::distance,这需要O(N)操作,因为multimap迭代器不是随机访问。另一种方法是使用排序的std::vector和std::binary_search算法。在这种情况下,搜索需要O(logN),但插入将需要O(N)操作,因为插入vector中间是线性操作。那么,是否有std/boos

c++ - 尾调用优化似乎会稍微降低性能

在快速排序实现中,左侧的数据是针对纯-O2优化的代码,右侧的数据是针对-O2优化的代码(已启用-fno-optimize-sibling-calls标志),即关闭了尾部调用优化功能。这是3次不同运行的平均值,变化似乎可以忽略不计。值的范围是1-1000,以毫秒为单位。编译器是MinGWg++,版本6.3.0。sizeofarraywithTLO(ms)withoutTLO(ms)8M35,08334,0514M8,9528,6271M613609下面是我的代码:#includeusingnamespacestd;intN=4000000;voidqsort(int*arr,intsta

c++ - 是否有用于存储离散间隔的集合?

我需要将离散范围存储在一个集合中,并在插入时连接相邻范围。STL中是否有结构已经具有这样的功能?我已经尝试过boost::intervals,但它很重,而且对于我正在尝试做的事情来说有点矫枉过正。例如,假设集合为空并插入了以下元素:[64,96][0,4][11,15][5,10]区间集合的预期内容应该如下:[0,15][64,96] 最佳答案 这是一个众所周知的问题。有一个wikipediapage关于您问题的可能解决方案。当然,在C++STL中,您可以使用std::map实现基于Naive方法的解决方案,在维基百科中有解释,因为

c++ - 从其他 vector 创建新 vector ,仅使用重复项

假设我有一组vector:std::vectora={2,3,8,4,9,0,6,10,5,7,1};std::vectorb={6,10,8,2,4,0};std::vectorc={0,1,2,4,5,8};我想创建一个新vector,这样只有所有输入vector共有的元素才会被输入到新vector中,如下所示:std::vectorabc={8,2,0,8};//possibleoutput,orderdoesn'tmatter我看到很多关于如何删除重复项的问题,但我希望保留仅重复项。是否有现成的高效STL算法或构造可以为我执行此操作,还是我需要自己编写?

c++ - 提升图形库 : Is there a neat algorithm built into BGL for community detection?

有人在大型生产服务器上使用BGL吗?您的网络由多少个节点组成?你如何处理communitydetectionBGL有什么很棒的方法来检测社区吗?有时两个社区可能通过一条或两条边连接在一起,但这些边并不可靠并且会逐渐消失。有时根本没有边缘。有人能简单谈谈如何解决这个问题吗?请打开我的思路并启发我。到目前为止,我已经设法计算出两个节点是否在一个岛上(在一个社区中)以最便宜的方式,但现在我需要计算出不同岛屿上的哪两个节点彼此最接近。我们只能尽量少地使用不可靠的地理数据。如果我们把它形象地比作一个大陆和一个岛屿,并把它从社会距离的背景中拿出来。我想计算出水域中哪两block土地距离最近。

c++ - 从 'triangle-soup' 中查找唯一顶点

我正在两个库(Opencascade和DWF工具包)之上构建一个CAD文件转换器。但是,我的问题与平台无关:给定:我生成了一个网格,作为三角形面的列表,形成了通过我的应用程序构建的模型。每个三角形都是通过三个顶点定义的,三个顶点由三个float(x、y和z坐标)组成。由于三角形形成一个网格,大部分顶点由多个三角形共享。目标:我需要找到唯一顶点的列表,并生成一个由该列表中三个索引的元组组成的面数组。我想做的是://step1:buildalistofuniqueverticesforeachtriangleforeachvertexintriangleifnotvertexinlistO

c++ - 关于multi-probe Local Sensitive Hashing的问题

很抱歉问这种菜鸟问题,但因为我真的非常急需一些关于如何使用MultiprobeLSH的指导,所以我自己没有做太多研究。我意识到有一个lib调用LSHKIT可以实现该算法,但我在尝试弄清楚如何使用它时遇到了麻烦。现在,我有几千个296维的特征向量,每个代表一个图像。该vector用于查询用户输入的图像,以检索最相似的图像。我用来推导vector之间距离的方法是欧氏距离。我知道这可能是一个相当菜鸟的问题,但是你们知道我应该如何实现多探针LSH吗?我真的非常感谢任何答复或回复。--更新--尝试使用提供的工具fitdata为我的数据创建模型,但它似乎没有包含我的文件。我用于输入的格式是这种格式

c++ - 将 std::sort 限制为随机访问迭代器

我只是想知道,既然你只能将随机访问迭代器传递给std::sort,为什么不首先通过只为随机访问迭代器定义它来强制执行该限制?#include#includetemplatetypenamestd::enable_if::iterator_category,std::random_access_iterator_tag>::value,void>::typesort(ForwardIteratorbegin,ForwardIteratorend){//...}我发现单行错误消息比在实现过程中因类型错误导致的一页又一页的错误消息更容易阅读。您可以对其他算法执行相同的操作。标准的C++核心语

c++ - Cython vector 操作

我如何使用remove来自的函数?(或任何其他操作,我想将其与vector一起使用,我尝试使用cdefextern来声明它,但我认为还没有模板函数) 最佳答案 Cython只能合理地链接到一些遵循C调用约定的外部库中的已编译代码。要使用模板函数,您必须编写一个使用特定算法体现的extern"C"包装函数(即,您必须修复模板参数)。 关于c++-Cythonvector操作,我们在StackOverflow上找到一个类似的问题: https://stackove