poj 1862 贪心

原创 2017年01月03日 14:05:14

题意:从N个数任取两个数按2*sqrt(a*b)合成新数放回,求最后那个数的最小值。

思路:贪心,每次取最大的2个数,计算结果后,再放回原来的数列中区,再排序,再取最大2个数,一直进行到只剩1个数

#include<stdio.h>
#include<math.h>
double worm[111];
void qsort(int l,int r)    //快速排序     最好用优先队列(但是我不会用C写优先队列,C++中有STL,可以直接用)
                                          //每次取最大的2个数

{
             int i,j;
             double temp;
             if(l<r)
             {
                     i=l;
                     j=r;
                     temp=worm[l];

                     while(i<j)
                     {
                           while(i<j&&worm[j]>=temp)
                                    j--;
                           if(i<j)
                              worm[i++]=worm[j];
                           while(i<j&&worm[i]<temp)
                                    i++;
                          if(i<j)
                              worm[j--]=worm[i];
                     }
                 worm[i]=temp;
                 qsort(l,i-1);
                 qsort(i+1,r);
            }
}
int main(void)
{
              int i,N; 
              scanf("%d",&N);
              for(i=0;i<N;i++)
                   scanf("%lf",&worm[i]);
             qsort(0,N-1);
             while(N>1)
             {
                        worm[N-2]=2*sqrt(worm[N-1]*worm[N-2]);
                        N--;
                       qsort(0,N-1);
             }
             printf("%.3lf\n",worm[0]);
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

POJ 1862 & ZOJ 1543 Stripies(贪心 | 优先队列)

POJ 1862 & ZOJ 1543 Stripies(贪心 | 优先队列)

POJ 1862 - Stripies(贪心)

Description Our chemical biologists have invented a new very useful form of life called stripies (i...

POJ 1862 Stripies (贪心、优先队列)

Stripies Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 12784   Acce...
  • lwt36
  • lwt36
  • 2015年02月23日 23:06
  • 297

poj 1862 还是哈夫曼思想贪心

题意:科学家发现一种奇怪的玩意,他们有重量Wi,             如果他们碰在一起,总重变成2*sqrt(t1*t2)。             要求出最终的重量的最小值。 思路:果然A...
  • lhrsdl
  • lhrsdl
  • 2015年02月19日 22:32
  • 431

《挑战程序设计竞赛》2.2.2 贪心法-其它 POJ3617 3069 3253 2393 1017 3040 1862 3262

POJ3617Best Cow Line题意给定长度为N的字符串S,要构造一个长度为N的字符串T。起初,T是一个空串,随后反复进行下列任意操作: 从S的头部(或尾部)删除一个字符,加到T的尾部 目...

【原创】【合并类贪心】POJ 3253 1862 2709; Fence Repair && Stripies && Painter

合并类贪心基础题和原理解释首先这里有个合并类的基础题目,合并果子(分卷子)。(不是合并石子),本次的主角就是它(还有优先队列),而这道题目和代码就丢在:这个链接里了,还有一道87%一模一样的题叫做分卷...

POJ 1862 Stripies 贪心

看了一些题解,他们推出当n = 3时,是先用两个最大的数合并,再和第三个数合并,这样是最佳方案。然后就归纳出了n>3也是这样,每次取出两个最大的数字合并。 可是我还是不太明白,n = 3的结论是怎么...

POJ1862 Stripies 【贪心】

Stripies Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 12522   Acce...

poj1862Stripies【哈夫曼合并木棍】

Description Our chemical biologists have invented a new very useful form of life called stripies (i...

POJ 1862- Stripies(优先队列)

M - Stripies Time Limit:1000MS     Memory Limit:30000KB     64bit IO Format:%I64d & %I64u Submit...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:poj 1862 贪心
举报原因:
原因补充:

(最多只允许输入30个字)