poj 1862 贪心

题意:从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
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值