您的位置:首页 > 其它

poj 1862 贪心

2017-01-03 14:05 141 查看
题意:从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