草庐IT

algorithm

全部标签

c++ - 在多列上对二维数组进行排序

我需要使用C或C++对多列double二维数组进行排序。有人可以指出我应该使用的算法或具有此功能的现有库(也许是boost?)吗?我觉得写一个递归函数可能是可行的方法,但我懒得写出算法或自己实现它,如果它已经在别处完成了。:-)谢谢 最佳答案 您可以使用std::sort(C++)或qsort(C或C++)来执行排序操作。棘手的部分是您需要定义一个自定义比较函数来比较您的行。例如:boolcompareTwoRows(double*rowA,double*rowB){return((rowA[0]

c++ - malloc 和 new 的实现差异。堆栈实现?

分配内存时,如果内存不可用,new运算符会抛出异常。另一方面,malloc返回NULL。执行差异的原因是什么。另外,在静态内存分配上,即在堆栈上,如果我们用完内存是否会出现异常?我已经浏览过链接Whatisthedifferencebetweennew/deleteandmalloc/free?但是没有得到我关于两者实现上的区别的答案 最佳答案 C代码的问题在于您应该检查函数的返回值以确保它们正常工作。但是编写的很多代码都没有检查返回值,结果在您最意想不到的时候炸毁了。在最坏的情况下,它甚至不会立即崩溃,而是继续在错误下游数英里的某

c++ - 如何使用时间复杂度优于 O(n^2) 的 STL vector 和 STL 算法进行左连接?

我有2个vector,其中包含Person(名字、姓氏等)对象。我想取其中一个vector(我们将其命名为“大”),然后针对该vector中的每个元素在第二个vector(“小”)中找到相应的元素,并将一些数据从“小”vector元素合并到“大”vector元素。此操作与SQL术语中的左连接非常相似,但具有额外的数据合并。最简单的方法是进行2个循环,但这会导致O(n^2)时间复杂度。我可以使用STL算法做得更好吗? 最佳答案 如果你sort小vector,然后您可以通过扫描大vector并使用binary_search获得合并部分的

c++ - 求和特定数字以获得 100 的不同方法

我想写一段代码来显示有多少种方法可以将5个不同的数字相加得到100。例如,数字是2,5,10,20,50,它们可以重复任意次数。这里50+50是一种方式,20+20+20+20+20。我不知道如何对此进行编程。我认为它应该通过一个递归函数来完成,我已经尝试编写一个但实际上不知道如何编写,所以这是我想出的最好的:#include#includeusingnamespacestd;inti,sum,n=5,counter=0;intadd(vector&m){if(m.size()==0)return0;for(i=0;i0)n--;m.resize(n);}}int_tmain(inta

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++ - 如何优化动态规划?

ProblemAnumberiscalledluckyifthesumofitsdigits,aswellasthesumofthesquaresofitsdigitsisaprimenumber.HowmanynumbersbetweenAandBarelucky?Input:ThefirstlinecontainsthenumberoftestcasesT.EachofthenextTlinescontainstwointegers,AandB.Output:OutputTlines,oneforeachcasecontainingtherequiredanswerfortheco

c++ - 实现格雷厄姆扫描以找到凸包

我正在尝试实现GrahamScan在C++中,但它不起作用,我找不到原因。任何线索将不胜感激。经过一些尝试后,似乎我总是有m_M=2并且这2个点是最高的y点,如果有帮助的话。通过叉积判断是右转还是左转。qrealInterpolation::ccw(QPointFpt1,QPointFpt2,QPointFpt3){return(pt2.x()-pt1.x())*(pt3.y()-pt1.y())-(pt2.y()-pt1.y())*(pt3.x()-pt1.x());}点积除以范数得到cos,因为对角度排序与对[0,Pi]中的cos排序相同。qrealInterpolation::d

c++ - Rabin-Karp 算法的最佳哈希函数是什么?

我正在为Rabin-Karp算法寻找高效的哈希函数。这是我的实际代码(C编程语言)。staticboolf2(charconst*consts1,size_tconstn1,charconst*consts2,size_tconstn2){uintmax_thsub=hash(s2,n2);uintmax_ths=hash(s1,n1);size_tnmax=n2-n1;for(size_ti=0;i我考虑了一些Rabin-KarpC实现,但所有代码之间存在差异。所以我的问题是:Rabin-Karp哈希函数应该具备哪些特征? 最佳答案

c++ - 将 2x32 位大整数除以 1000

我有很大的数字,时间(微秒)存储在两个32位变量中。我需要帮助,如何将微秒时间更改为毫秒,以便我可以将差异结果存储在32位数字中。更多详情:我曾经有过两个32位变量。其中一个变量具有较高有效位而其他变量具有较低有效位。这次有微秒分辨率,所以我想把它改成毫秒。那么如何划分存储在两个变量中的数字。 最佳答案 如果你没有64位类型,你可以像下面这样:uint32_thigher,lower;//yourinputlower/=1000;lower+=(higher%1000)*4294967L;//approximate2^32/1000

c++ - 建议一个合适的算法来合并两个包含类对象的数组(不重复)

我有一个数组,其中每个位置都包含一个具有三个int值(x,y,z)的类对象。现在必须从不同的数组中将所有元素复制到源数组中。对于每个数组元素,我们需要检查x、y、z值以避免重复。有没有可能比o(n^2)更有效? 最佳答案 前提是你不介意丢失两个数组原来的顺序:std::sort(first_array,first_array+N);std::sort(second_array,second_array+M);std::set_union(first_array,first_array+N,second_array,second_ar