我目前正在写一个记忆游戏,而且我在检查我的阵列时遇到了一些问题。该计划如何运作:
当有人猜测时,它会检查瓷砖并将瓷砖保存在机器人的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
答案 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;
};