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

问题描述 投票:1回答:2

我正在学习C ++,下面的代码想要一些功能帮助。我的代码的快速摘要/用法:程序将显示随机(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";
}

当前输出:

“”

如您所见,每个“城市坐标”都有一个单独的网格

c++ loops random grid coordinates
2个回答
0
投票

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

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

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;
}

-1
投票

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

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";
}

输出:

enter image description here

© www.soinside.com 2019 - 2024. All rights reserved.