对于压缩矩阵,分段断裂没有任何意义
Seg faulting doesnt make any sense with compressed matrix
我正在创建一个城市的距离矩阵。考虑到你在城市之间旅行的距离是一样的,我将数据存储在矢量中,并使用特殊的索引系统来访问它,这样我就不必存储数据两次。问题是,当我去输出数据时,程序分段错误,这是没有意义的。
下面是从距离矩阵中打印出来的代码部分。矩阵大小是630。最后一个索引输出到cout是629,这应该意味着我很好。不知何故,它不是。有线索吗?
output << "DISTANCE table:n";
output << "size = : " << distance_mat.size() << endl;
int ibase,iindex;
int k = 0;
for(int i = 0; i < distance_mat.size(); i++){
for(int j = 0; j <= i; j++){
ibase = i*(i+1)/2;
iindex = ibase + j;
output << setw(3) << right << i << " " << cities[i].Name << " to " << cities[j].Name << ": ";
cout << iindex << " " << distance_mat.size() << endl;
output << fixed << setprecision(2) << distance_mat[iindex] << " milesn";
}
}
cout << "ummmmmmm?" << endl;
output.close();
Ummmmm永远不会输出,最后打印的值甚至与distance_mat[629]不匹配。
假设distance_mat.size() = 630
然后看到最后一次迭代:
iindex = ibase + j = 629 * 630 / 2 = 198135
,然后尝试访问j=0
: distance_mat[iindex=198135]
…而你没有……感觉算法有问题
相关文章:
- 分段故障(堆芯转储)矢量
- 如果C++类在类方法中具有动态分配,但没有构造函数/析构函数或任何非静态成员,那么它仍然是POD类型吗
- 数组的指针从不分段故障
- 在某些循环内使用vector.push_back时出现分段错误
- 为什么在运行时没有向我们提供有关分段错误的更多信息?
- 奇怪的(对我来说)返回声明 - 在谷歌上找不到任何关于它的信息
- 在线编译器中的分段C++没有打印消息
- 如何在不产生任何垃圾的情况下获得C中的像素
- 为什么我不能在 C++ 中的特定函数重载中调用同一函数的任何其他重载?
- 如何解决gcc编译器优化导致的centos双编译器设置中的分段错误
- 当我的阵列太大时出现分段错误
- Windows 10-使用gtkmm-3.0库和g++[包括再现]的分段故障
- 分段错误当我试图运行程序时出错
- 在c++中初始化矩阵时出现分段错误(核心转储)
- 尝试使用集合函数时出现分段错误
- 当我在将文件读取到C字符串的2D数组后尝试对任何内容进行定制时,C++分段错误
- 除 "6" 作为最右边数字的整数输入外,任何整数输入都可以使用,但任何数字(如 ...6.导致分段错误,为什么?
- 任何耶普的分段错误!接口调用
- 这个循环不断为我提供任何修复的分段错误
- 对于压缩矩阵,分段断裂没有任何意义