要實現24點游戲計算器,可以使用遞歸的方法來進行計算。以下是一個簡單的C語言實現:
#include <stdio.h>
#include <stdbool.h>
#define TARGET 24
#define EPSILON 1e-6
bool solve24(double nums[], int n) {
if (n == 1) {
// 如果只剩下一個數,判斷是否等于24
if (fabs(nums[0] - TARGET) < EPSILON) {
return true;
} else {
return false;
}
}
// 選擇兩個數字進行計算
for (int i = 0; i < n; i++) {
for (int j = i + 1; j < n; j++) {
// 生成新數組,將選中的兩個數字合并為一個數字,并將其它數字拷貝到新數組中
double newNums[n - 1];
int idx = 0;
for (int k = 0; k < n; k++) {
if (k != i && k != j) {
newNums[idx++] = nums[k];
}
}
// 嘗試四種運算操作
newNums[idx] = nums[i] + nums[j];
if (solve24(newNums, n - 1)) {
return true;
}
newNums[idx] = nums[i] - nums[j];
if (solve24(newNums, n - 1)) {
return true;
}
newNums[idx] = nums[i] * nums[j];
if (solve24(newNums, n - 1)) {
return true;
}
if (nums[j] != 0) {
newNums[idx] = nums[i] / nums[j];
if (solve24(newNums, n - 1)) {
return true;
}
}
}
}
return false;
}
int main() {
double nums[4];
// 輸入四個數字
printf("請輸入四個數字:\n");
for (int i = 0; i < 4; i++) {
scanf("%lf", &nums[i]);
}
// 判斷是否能夠計算出24
if (solve24(nums, 4)) {
printf("能夠計算出24\n");
} else {
printf("無法計算出24\n");
}
return 0;
}
此程序通過遞歸的方式,不斷地選擇兩個數字進行計算,生成新的數字數組,并再次調用自身進行計算,直到只剩下一個數字為止。在每一次計算中,嘗試四種運算操作(加、減、乘、除),并將結果存入新的數字數組中。最后,判斷最終的結果是否等于24。