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

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

POJ - 1862 貪心

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

一道水題,貪心 給你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]);
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 中西区| 名山县| 灵丘县| 满洲里市| 花莲县| 山阴县| 江川县| 山阳县| 农安县| 北票市| 磐石市| 友谊县| 库伦旗| 玉龙| 凌云县| 三亚市| 连江县| 汉川市| 横峰县| 彩票| 沙洋县| 英吉沙县| 雷山县| 龙泉市| 息烽县| 沁水县| 济源市| 长沙县| 九江县| 沐川县| 娄底市| 芜湖县| 白玉县| 牟定县| 上栗县| 广东省| 庄浪县| 德化县| 延吉市| 吴桥县| 石屏县|