关闭

poj 1862 贪心

标签: poj快速排序 1862
123人阅读 评论(0) 收藏 举报
分类:

题意:从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]);
}

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:31414次
    • 积分:3502
    • 等级:
    • 排名:第9457名
    • 原创:337篇
    • 转载:1篇
    • 译文:0篇
    • 评论:1条
    博客专栏
    最新评论