Криптарифметическая головоломка
Я пытаюсь решить эту криптарифметическую головоломку ДВА + ДВА = ЧЕТЫРЕ, и я использовал грубую грубую силу, но я не могу понять, где я делаю ошибку. Идея здесь состоит в том, что он пробует все возможные комбинации чисел от 0 до 10, и все числа, которые назначены символам, должны быть различны. По определению
Криптарифметическая головоломка - это математическая игра, в которой цифры некоторых чисел представлены буквами (или символами). Каждая буква представляет собой уникальную цифру. Цель состоит в том, чтобы найти цифры так, чтобы данное математическое уравнение было проверено: В этом случае:
TWO
+ TWO
------
= FOUR
Этот код проходит через все возможные комбинации, пока не найдет решение, которое удовлетворит проблему. Ограничение на это дано в else if
заявление. Первый if
оператор просто проверяет, совпадают ли числа, и если они есть, он просто пропускает эту итерацию.
Мой желаемый результат - видеть все правильные решения.
int T, W, O, F, U, R;
for (T = 0; T < 10; T++)
{
for (W = 0; W < 10; W++)
{
for (O = 0; O < 10; O++)
{
for (F = 0; F < 10; F++)
{
for (U = 0; U < 10; U++)
{
for (R = 0; R < 10; R++)
{
if ((T == W) || (T == O) || (T == F) || (T == U) || (T == R) || (W == O) || (W == F) || (W == U) || (W == R) || (O == F) || (O == U) || (O == R) || (F == U) || (F == R) || (U == R))
{
continue;
}
else if (200 * T + 20 * W + 2 * O == F * 1000 + O * 100 + U * 10 + R * 0) {
cout << "T = " << T << endl
<< "W = " << W << endl
<< "O = " << O << endl
<< "F = " << F << endl
<< "U = " << U << endl
<< "R = " << R << endl << endl;
break;
}
}
}
}
}
}
}
Я получаю кучу результатов и, что интересно, только последний результат хорош, где он дает:
T = 7
W = 6
O = 5
F = 1
U = 3
R = 0
1 ответ
R * 0
должно быть R * 1
,
Ответ, который вы получили, оказался правильным, был тот, где R = 0
(потому что когда R
является 0
, R * 0
такой же как R * 1
). Я думаю, вы тоже хотите начать F
от 1
как правило, криптарифмы не допускают начальные нули.