国产探花免费观看_亚洲丰满少妇自慰呻吟_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]);
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 彩票| 临高县| 通山县| 汉沽区| 新郑市| 额敏县| 景东| 邢台市| 龙里县| 榆中县| 买车| 博乐市| 镇远县| 武穴市| 郓城县| 池州市| 永和县| 和田市| 驻马店市| 澄迈县| 洪泽县| 绿春县| 来安县| 鄂伦春自治旗| 平阳县| 墨竹工卡县| 辽宁省| 德昌县| 景谷| SHOW| 淳安县| 五华县| 马尔康县| 新平| 保德县| 乌拉特中旗| 平顶山市| 抚顺县| 马龙县| 建阳市| 尉犁县|