C璇█鎬庝箞瀹炵幇24鐐规父鎴忚绠楀櫒
瑕佸疄鐜?4鐐规父鎴忚绠楀櫒锛屽彲浠ヤ娇鐢ㄩ€掑綊鐨勬柟娉曟潵杩涜璁$畻銆備互涓嬫槸涓€涓畝鍗曠殑C璇█瀹炵幇锛?/p>
#include <stdio.h>
#include <stdbool.h>
#define TARGET 24
#define EPSILON 1e-6
bool solve24(double nums[], int n) {
if (n == 1) {
// 濡傛灉鍙墿涓嬩竴涓暟锛屽垽鏂槸鍚︾瓑浜?4
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++) {
// 鐢熸垚鏂版暟缁勶紝灏嗛€変腑鐨勪袱涓暟瀛楀悎骞朵负涓€涓暟瀛楋紝骞跺皢鍏跺畠鏁板瓧鎷疯礉鍒版柊鏁扮粍涓?/span>
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]);
}
// 鍒ゆ柇鏄惁鑳藉璁$畻鍑?4
if (solve24(nums, 4)) {
printf("鑳藉璁$畻鍑?4\n");
} else {
printf("鏃犳硶璁$畻鍑?4\n");
}
return 0;
}
姝ょ▼搴忛€氳繃閫掑綊鐨勬柟寮忥紝涓嶆柇鍦伴€夋嫨涓や釜鏁板瓧杩涜璁$畻锛岀敓鎴愭柊鐨勬暟瀛楁暟缁勶紝骞跺啀娆¤皟鐢ㄨ嚜韬繘琛岃绠楋紝鐩村埌鍙墿涓嬩竴涓暟瀛椾负姝€傚湪姣忎竴娆¤绠椾腑锛屽皾璇曞洓绉嶈繍绠楁搷浣滐紙鍔犮€佸噺銆佷箻銆侀櫎锛夛紝骞跺皢缁撴灉瀛樺叆鏂扮殑鏁板瓧鏁扮粍涓€傛渶鍚庯紝鍒ゆ柇鏈€缁堢殑缁撴灉鏄惁绛変簬24銆?/p>
相关问答