国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

遞歸之算24

2019-11-11 00:42:05
字體:
來源:轉載
供稿:網友

描述:

給出4個小于10的正整數,你可以使用加減乘除以及括號把這四個數字連接起來得到一個表達式,現在的問題是,是否存在一種方式使得到的結果剛好為24, 這里加減乘除以及括號的運算結果以及優先級和我們平時的定義一樣,(除法是實數除法) 例:5 5 5 1 5*(5-1/5)=24 1 1 4 2 無法得到24

代碼實現

#include<iostream>#include<cmath>#define EPS 1e-6using namespace std;bool IsZero(double n){ return fabs(n) <= EPS;}bool Count24(double a[],int n){ if( n == 1) { if(IsZero(a[0] - 24)) return true; else return false; } else { double b[5]; for(int i = 0;i < n-1; i++) { for(int j = i+1;j < n;j++) { int m = 0; for(int k = 0;k < n;k++) if(k != i && k != j) b[m++] = a[k]; b[m] = a[i] + a[j]; if(Count24(b,m+1)) return true; b[m] = a[i] - a[j]; if(Count24(b,m+1)) return true; b[m] = a[j] - a[i]; if(Count24(b,m+1)) return true; b[m] = a[i] * a[j]; if(Count24(b,m+1)) return true; if(!IsZero(a[j])) { b[m] = a[i] / a[j]; if(Count24(b,m+1)) return true; } if(!IsZero(a[i])) { b[m] = a[j] / a[i]; if(Count24(b,m+1)) return true; } } } } return false; } int main() { double a[5]; for(int i = 0;i < 4;i++) cin >> a[i]; while(a[0] != 0) { if(Count24(a,4)) cout << "YES" << endl; else cout << "NO" << endl; for(int i = 0;i < 4;i++) cin >> a[i]; } return 0; }
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 太康县| 山阳县| 荔浦县| 滕州市| 临清市| 大邑县| 东乌珠穆沁旗| 突泉县| 通州市| 饶阳县| 广元市| 泽普县| 潢川县| 朔州市| 金山区| 沂源县| 沅江市| 扎赉特旗| 太康县| 永定县| 南康市| 邹城市| 临汾市| 怀化市| 济南市| 柘荣县| 永宁县| 蓬安县| 沧州市| 紫阳县| 梨树县| 米易县| 北票市| 仙桃市| 磴口县| 濉溪县| 绍兴县| 台前县| 龙胜| 普洱| 禹城市|