如何使用loop一次性显示循环信息?功能问题

How to use loop to display looped information all at once? Functionality Issue

我正在学习 C++,希望在功能方面 帮助我的以下代码。 快速 summary/usage 我的代码:程序是显示随机的 (x,y) 坐标,然后在网格中打印出坐标。

关于随机化 (x,y) 坐标然后显示它们的网格位置,我已经完成了所有工作。

我遇到的问题是我的代码为每个坐标显示一个单独的网格,而不是在同一网格上显示所有坐标。 [我在下面附上了我当前输出的图片]。

我知道这是一个功能问题..但我无法思考如何操作我的循环以便首先显示坐标,然后显示一个包含所有坐标的网格...我希望这是有道理的。

我的代码片段:

//Note: value of n and k is given by user earlier in the code
vector<vector<int> > vec( n , vector<int> (n));
cout << "\nGrid with city locations:\n";
for(i=0; i<k; i++) {
    //random select int coordinates (x,y) for each K(cities) 
    x = rand() % n + 0; 
    y = rand() % n + 0;
    arrCity[i] = i;

    //display coordinates for city 1..city2.. etc
    cout << "City " << arrCity[i] <<": (" << x << "," << y << ")" << endl;

    //display cities on grid
    for (int rows=0; rows < n; rows++) {
        for (int columns=0; columns < n; columns++) {
            if ((rows == y) && (columns == x)) {
                cout << "|" << (i);
            } else {
                cout << "|_";
            }

        }
        cout << "\n";
    }
    cout << "\n";
}

当前输出:

如您所见,每个 'city coordinate'

都有一个单独的网格

您需要存储所有城市坐标,以便在单个网格打印中显示它们。 在下面的代码中,我更改了一些内容,希望能解决您的问题。

  • 我已将所有与城市相关的数据移动到一个结构中
  • 然后在网格输出前初始化所有城市
  • 打印网格时,我们要搜索所有城市,如果坐标与当前位置匹配,则打印相应的索引。

Live Demo

#include <vector>
#include <iostream>

struct City
{
    int index;
    int x, y;

    City(int index_, int x_, int y_)
        : index(index_), x(x_), y(y_)
    { }
};

int main()
{
    int n = 10;
    int k = 6;

    std::vector<City> arrCity;
    arrCity.reserve(k);

    for(int i = 0; i < k; i++)
        arrCity.emplace_back(i, rand() % n, rand() % n);

    std::cout << "\nGrid with city locations:\n";

    for (int k = 0; k < arrCity.size(); k++)
        std::cout << "City " << arrCity[k].index << ": (" << arrCity[k].x << "," << arrCity[k].y << ")" << std::endl;

    //display cities on grid
    for (int i=0; i < n; i++) {
        for (int j=0; j < n; j++) {
            int w = -1;
            for (int k = 0; k < arrCity.size(); k++)
                if ((i == arrCity[k].y) && (j == arrCity[k].x))
                    w = k;

            if (w >= 0)
                std::cout << "|" << arrCity[w].index;
            else
                std::cout << "|_";
        }
        std::cout << "\n";
    }

    return 0;
}

您需要跟踪哪些单元格已经被访问过。这就是为什么您需要采用另一个数组来存储已经访问过的单元格以及访问过的值。

int vis[n][n];
memset(vis, -1, sizeof vis);

for(i=0; i<k; i++) {
    //random select int coordinates (x,y) for each K(cities)
    x = rand() % n + 0;
    y = rand() % n + 0;
    arrCity[i] = i;
    vis[x][y] = i;

    //display coordinates for city 1..city2.. etc
    cout << "City " << arrCity[i] <<": (" << x << "," << y << ")" << endl;

    //display cities on grid
    for (int rows=0; rows < n; rows++) {
        for (int columns=0; columns < n; columns++) {
            if (vis[rows][columns] != -1) {
                cout << "|" << (vis[rows][columns]);
            } else {
                cout << "|_";
            }

        }
        cout << "\n";
    }
    cout << "\n";
}

输出: