检查两个不同的2D数组以找到匹配c ++

时间:2016-08-26 12:15:48

标签: c++ arrays multidimensional-array

我目前正在写一个记忆游戏,而且我在检查我的阵列时遇到了一些问题。该计划如何运作:

当有人猜测时,它会检查瓷砖并将瓷砖保存在机器人的2D数组中,这样机器人就可以记住电路板上的东西。

我正在尝试编写一个用于循环的2D数组,用于检查包含答案的2D数组与机器人的2D数组之间的匹配。

当找到匹配项时,我想保存这些值,但是我的程序目前还没有这样做,

我想了解一下我的for循环错误。 我环顾四周,阅读了一些我的C ++教科书,但找不到任何东西。 Output

 //2d Arrays
//bot array changes each time someone guesses

string botArray[6][6] = {
    { "-", "-", "-", "-", "-", "-" },
    { "-", "-", "-", "-", "-", "-" },
    { "-", "-", "-", "-", "-", "-" },
    { "-", "-", "-", "-", "-", "-" },
    { "-", "-", "-", "-", "-", "-" },
    { "-", "-", "-", "-", "-", "-" }
};
string pairs[6][6] = { 
{ "a", "a", "b", "b", "c", "c" },
{ "d", "d", "e", "e", "f", "f" },
{ "g", "g", "h", "h", "i", "i" },
{ "j", "j", "k", "k", "l", "l" },
{ "m", "m", "n", "n", "o", "o" },
{ "p", "p", "q", "q", "r", "r" }
 };

                  for (int r1 = 0; r1 < 6; r1++) {
                    for (int c1 = 0; c1 < 6; c1++) {
                        for (int r2 = 0; r2 < 6; r2++) {
                            for (int c2 = 0; c2 < 6; c2++) {
                                if (botArray[r1][c1] == pairs[r1][c1]){
                                   if(botArray[r2][c2] == pairs[r2][c2]) {
                                     if (r1 != r2 && c1 != c2) {
                                    row1 = r1;
                                    col1 = c1;
                                    row2 = r2;
                                    col2 = c2;
                                }
                               }
                                else{
                                    row1 = rand() % 6 + 1;
                                    row2 = rand() % 6 + 1;
                                    col1 = rand() % 6 + 1;
                                    col2 = rand() % 6 + 1;
                                }
                            }
                        }
                    }
                }
             }
//values are printed outside of the for loop after
//they are assigned in the if statement

1 个答案:

答案 0 :(得分:0)

目前,您的逻辑错误(添加评论)

// Loop
if (botArray[r1][c1] == pairs[r1][c1]) { // Bot knows that case
    if (botArray[r2][c2] == pairs[r2][c2]) { // Bot knows that case
        if (r1 != r2 && c1 != c2) { // Different case
            row1 = r1;
            col1 = c1;
            row2 = r2;
            col2 = c2;
        }
    } else { // Hit each time that we found a second unknown case
             // So overwrite previous found solution
        row1 = rand() % 6 + 1;
        row2 = rand() % 6 + 1;
        col1 = rand() % 6 + 1;
        col2 = rand() % 6 + 1;
    }
}

应该是

// Loop
if ((r1 != r2 || c1 != c2) // Different case
    && botArray[r1][c1] != "-" // Known card
    && botArray[r1][c1] == botArray[r2][c2]) // Pair found
    // Missing: Not already displayed
{
    row1 = r1;
    col1 = c1;
    row2 = r2;
    col2 = c2;
    return; // No need more processing
}

// and after loop, to handle when no pair found
do {
    row1 = rand() % 6 + 1; // Random play
    row2 = rand() % 6 + 1;
    col1 = rand() % 6 + 1;
    col2 = rand() % 6 + 1;
} while ((row1 != row2 || col1 != col2) // Different case
         // Potentially other condition, as at least one unknown case
     )

我会实现类似的东西:

class BotPlayer
{
public:
    explicit BotPlayer(std::size_t size) {
        for (std::size_t i = 0; i != size; ++i) {
            data.emplace_back(i, "");
        }
    }

    std::pair<std::size_t, std::size_t> selectMove() {
        // Try to find 2 cards with same value
        std::sort(data.begin(), data.end(), [](const auto& lhs, const auto& rhs){ return lhs.second < rhs.second; } );
        auto it = std::adjacent_find(data.begin(), data.end(), [](const auto& lhs, const auto& rhs){ return lhs.second == rhs.second && !lhs.second.empty(); });

        if (it == data.end()) { // No known pairs -> play randomly (but choose unknown cards)
            auto isUnknown = [](const auto& e){ return e.second.empty(); };
            it = std::partition(data.begin(), data.end(), isUnknown);
            std::shuffle(data.begin(), it, rnd);
            it = data.begin();
        }
        return {it->first, std::next(it)->first};
    }

    void reveal(std::size_t pos, const std::string& value)
    {
        // Update our knowledge.
        std::cout << "> " << pos << " is " << value << std::endl;
        auto it = std::find_if(data.begin(), data.end(), [&](const auto& p) { return p.first == pos; });

        it->second = value;
    }

    void foundPair(std::size_t pos1, std::size_t pos2)
    {
        // So we don't have to worry about those cards anymore
        data.erase(std::find_if(data.begin(), data.end(), [&](const auto& p) { return p.first == pos1; }));
        data.erase(std::find_if(data.begin(), data.end(), [&](const auto& p) { return p.first == pos2; }));
    }

private:
    std::mt19937 rnd;

    // for each remaining position to play,
    // associate the associated value,
    // empty for unknown.
    std::vector<std::pair<int, std::string>> data;
};

Demo