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

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

POJ - 1862 貪心

2019-11-10 23:17:10
字體:
來源:轉載
供稿:網友

一道水題,貪心 給你n個數字,每兩個數字以2sqrt(a*b)的方式合并成一個數,最后n個數字全部合并成一個數字,問最小的結果。

思路:四個數字abcd,按abcd 的順序合并,最后的結果等于2sqrt(d*2sqrt(c*2sqrt(b*a))),可以看出,最先合并的數字被開根號的次數最多,所以越大的數字應該越靠里面,也就是越大的數字越先合并。 所以先排序,從大到小一個個合并

#include<cmath>#include<cstdio>#include<cstring>#include<iostream>#include<algorithm>using namespace std;const int MAXN = 105;double a[MAXN];int n;int main(){ while(scanf("%d", &n) == 1) { for(int i=0; i<n; i++) scanf("%lf", a+i); sort(a, a+n); double ans = a[n-1]; for(int i=n-2; i>=0; --i) ans = 2 * sqrt(ans*a[i]);
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宜丰县| 怀柔区| 修武县| 和田县| 崇左市| 汉源县| 花莲市| 禹州市| 松溪县| 尤溪县| 林州市| 滦南县| 汉阴县| 平塘县| 东乡县| 乃东县| 克山县| 柏乡县| 海伦市| 渑池县| 红桥区| 界首市| 阳新县| 元谋县| 宁阳县| 漳浦县| 兴国县| 安陆市| 来宾市| 克东县| 栾城县| 湟源县| 梧州市| 山西省| 腾冲县| 怀仁县| 同心县| 苏尼特右旗| 余江县| 庆云县| 五大连池市|