- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在编写一种算法,通过计算每个顶点组合的最小树来计算给定图上的斯坦纳树,但我的组合算法似乎无法正确管理内存使用,但我看不到我在哪里没能做到...
它的工作原理如下,该算法接收一个 vector ,其中包含必须始终包含在图中的顶点,因此第一件事是创建一个包含可选顶点的 vector ,我们将合并的顶点(我使用 10测试海豚),然后它计算从 1 个元素到 k 个元素的组合(k 小于可选顶点集的总大小)。
我们将生成索引的组合(代替直接元素,因为这样更容易),然后将这些索引中的元素包含在 vComb vector 中。
#include <iostream>
#include <vector>
using namespace std;
//Function that calculates the next combination
bool next_comb(vector<int>& indComb, const int k, const int n) {
int i = k - 1;
indComb[i]++;
while((i >= 0) && (indComb[i] >= n-k+1+i)){
i--;
indComb[i]++;
}
if (indComb[0] > n - k) //We've arrived to the combination (n-k, n-k+1, ..., n)
return false; //We can't generate more combinations
//Combination is in form(..., x, n, n, n, ..., n).
//We will put it in form (..., x, x + 1, x + 2, ...)
for (i = i + 1; i < k; ++i)
indComb[i] = indComb[i - 1] + 1;
return true;
}
//Checks if element is in vector
bool is_in(const int n,const vector<int> v){
for(int i=0; i<v.size(); i++)
if(n==v[i]) return true;
return false;
}
void ST(const vector<int> vMandatory){
cout << "V Mandatory: ";
for(int i=0;i<vMandatory.size();i++)
cout << vMandatory[i] << " ";
cout << " " << endl;
//Create and initializate the vector that contains the optional vertices
vector<int> vOptional(10-vMandatory.size());
int j=0;
for(int i=0;i<10;i++){
if(!is_in(i,vMandatory)){
vOptional[j] = i;
j++;
}
}
cout << "V Optional: ";
for(int i=0;i<vOptional.size();i++)
cout << vOptional[i] << " ";
cout << " " << endl;
int k = 1; //Initialize number of elements to combine
int n = vOptional.size(); //Number of elements inside de set to combine
vector<int> indComb; //Vector that will keep the combined indexes of the combination
vector<int> vComb; //Vector that will keep the combined elements
//We control that the number of elements in the combination can't exceed the number of elements in the set
while(k <= vOptional.size()){
indComb.resize(k);
vComb.resize(k);
//Preparare the first combination
for(int i=0;i<k;i++){
indComb[i] = i;
vComb[i] = vOptional[indComb[i]];
}
cout << "V Primera Combinación: ";
for(int i=0;i<vComb.size();i++)
cout << vComb[i] << " ";
cout << " " << endl;
//We make the rest of combinations
while(next_comb(indComb,k,n)){
for(int i=0;i<k;i++)
vComb[i] = vOptional[indComb[i]];
cout << "V Next Combinations: ";
for(int i=0;i<vComb.size();i++)
cout << vComb[i] << " ";
cout << " " << endl;
}
k++;
cout << k << endl;
}
}
int main(){
vector<int> vObligatorios(3);
vObligatorios[0] = 0;
vObligatorios[1] = 1;
vObligatorios[2] = 2;
ST(vObligatorios);
}
这是编译器给我的错误
*** Error in `./a.out': double free or corruption (out): 0x0000000001a880a0 ***
======= Backtrace: =========
/lib/x86_64-linux-gnu/libc.so.6(+0x777e5)[0x7f8f9a4c67e5]
/lib/x86_64-linux-gnu/libc.so.6(+0x7fe0a)[0x7f8f9a4cee0a]
/lib/x86_64-linux-gnu/libc.so.6(cfree+0x4c)[0x7f8f9a4d298c]
./a.out[0x402612]
./a.out[0x4022c4]
./a.out[0x401c98]
./a.out[0x40213e]
./a.out[0x401b78]
./a.out[0x401823]
./a.out[0x4010b4]
./a.out[0x40149c]
/lib/x86_64-linux-gnu/libc.so.6(__libc_start_main+0xf0)[0x7f8f9a46f830]
./a.out[0x400bb9]
======= Memory map: ========
00400000-00404000 r-xp 00000000 08:06 14156577 /home/pedro/Desktop/a.out
00603000-00604000 r--p 00003000 08:06 14156577 /home/pedro/Desktop/a.out
00604000-00605000 rw-p 00004000 08:06 14156577 /home/pedro/Desktop/a.out
01a76000-01aa8000 rw-p 00000000 00:00 0 [heap]
7f8f94000000-7f8f94021000 rw-p 00000000 00:00 0
7f8f94021000-7f8f98000000 ---p 00000000 00:00 0
7f8f9a146000-7f8f9a24e000 r-xp 00000000 08:06 2621535 /lib/x86_64-linux-gnu/libm-2.23.so
7f8f9a24e000-7f8f9a44d000 ---p 00108000 08:06 2621535 /lib/x86_64-linux-gnu/libm-2.23.so
7f8f9a44d000-7f8f9a44e000 r--p 00107000 08:06 2621535 /lib/x86_64-linux-gnu/libm-2.23.so
7f8f9a44e000-7f8f9a44f000 rw-p 00108000 08:06 2621535 /lib/x86_64-linux-gnu/libm-2.23.so
7f8f9a44f000-7f8f9a60e000 r-xp 00000000 08:06 2621530 /lib/x86_64-linux-gnu/libc-2.23.so
7f8f9a60e000-7f8f9a80e000 ---p 001bf000 08:06 2621530 /lib/x86_64-linux-gnu/libc-2.23.so
7f8f9a80e000-7f8f9a812000 r--p 001bf000 08:06 2621530 /lib/x86_64-linux-gnu/libc-2.23.so
7f8f9a812000-7f8f9a814000 rw-p 001c3000 08:06 2621530 /lib/x86_64-linux-gnu/libc-2.23.so
7f8f9a814000-7f8f9a818000 rw-p 00000000 00:00 0
7f8f9a818000-7f8f9a82e000 r-xp 00000000 08:06 2625962 /lib/x86_64-linux-gnu/libgcc_s.so.1
7f8f9a82e000-7f8f9aa2d000 ---p 00016000 08:06 2625962 /lib/x86_64-linux-gnu/libgcc_s.so.1
7f8f9aa2d000-7f8f9aa2e000 rw-p 00015000 08:06 2625962 /lib/x86_64-linux-gnu/libgcc_s.so.1
7f8f9aa2e000-7f8f9aba0000 r-xp 00000000 08:06 5244862 /usr/lib/x86_64-linux-gnu/libstdc++.so.6.0.21
7f8f9aba0000-7f8f9ada0000 ---p 00172000 08:06 5244862 /usr/lib/x86_64-linux-gnu/libstdc++.so.6.0.21
7f8f9ada0000-7f8f9adaa000 r--p 00172000 08:06 5244862 /usr/lib/x86_64-linux-gnu/libstdc++.so.6.0.21
7f8f9adaa000-7f8f9adac000 rw-p 0017c000 08:06 5244862 /usr/lib/x86_64-linux-gnu/libstdc++.so.6.0.21
7f8f9adac000-7f8f9adb0000 rw-p 00000000 00:00 0
7f8f9adb0000-7f8f9add6000 r-xp 00000000 08:06 2621445 /lib/x86_64-linux-gnu/ld-2.23.so
7f8f9afb4000-7f8f9afb9000 rw-p 00000000 00:00 0
7f8f9afd2000-7f8f9afd5000 rw-p 00000000 00:00 0
7f8f9afd5000-7f8f9afd6000 r--p 00025000 08:06 2621445 /lib/x86_64-linux-gnu/ld-2.23.so
7f8f9afd6000-7f8f9afd7000 rw-p 00026000 08:06 2621445 /lib/x86_64-linux-gnu/ld-2.23.so
7f8f9afd7000-7f8f9afd8000 rw-p 00000000 00:00 0
7ffd45daf000-7ffd45dd0000 rw-p 00000000 00:00 0 [stack]
7ffd45de6000-7ffd45de8000 r--p 00000000 00:00 0 [vvar]
7ffd45de8000-7ffd45dea000 r-xp 00000000 00:00 0 [vdso]
ffffffffff600000-ffffffffff601000 r-xp 00000000 00:00 0 [vsyscall]
Aborted (core dumped)
最佳答案
这里:
while((i >= 0) && (indComb[i] >= n-k+1+i)){
i--;
indComb[i]++;
}
你可以让i
为负,导致下一行未定义。
为该案例添加一些跟踪以验证它确实发生了。
(您可能会为 vector 的分配存储覆盖内存管理器的内部数据。)
关于c++ - 双自由或腐败(出): 0x0000000001a880a0 *** on combinatory algorithm using vectors,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43427273/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!