加载中...

15.8 距离矩阵


最后,我们准备把数据从文件读入一个矩阵中。具体来说,每个城市在该矩阵中都一个相应的行和列。

我们将在main函数中创建该矩阵,它会剩余大量空间:

  1. apmatrix<int> distances (50, 50, 0);

在processLine内部,我们从Set中得到两个城市的索引,并以这两个索引为矩阵的索引,向矩阵中添加了新信息:

  1. int dist = convertToInt (distString);
  2. int index1 = cities.add (city1);
  3. int index2 = cities.add (city2);
  4. distances[index1][index2] = distance;
  5. distances[index2][index1] = distance;

最后,在main函数中我们可以将信息以可读的形式打印出来:

  1. for (int i=0; i<cities.getNumElements(); i++) {
  2. cout << cities.getElement(i) << "\t";
  3. for (int j=0; j<=i; j++) {
  4. cout << distances[i][j] << "\t";
  5. }
  6. cout << endl;
  7. }
  8. cout << "\t";
  9. for (int i=0; i<cities.getNumElements(); i++) {
  10. cout << cities.getElement(i) << "\t";
  11. }
  12. cout << endl;

这段代码的输出就是本章开头的矩阵。原始数据可以从本书网站获取。


还没有评论.