uva10012(How Big Is It?)-简单回溯

这篇博客详细介绍了如何解决UVA10012问题,通过使用回溯算法来求解。文章内容包括题目链接及算法实现思路,适合初学者理解和实践。
摘要由CSDN通过智能技术生成

题目链接:点击打开链接

#include <cstdio>
#include <iostream>
#include <cstring>
#include <string>
#include <cmath>
#include <queue>
#include <algorithm>
#define inf 1<<26
#define maxn 10
#define maxe 1000000
using namespace std;

int n;
double r[maxn];
double p[maxn];

int main()
{
   // freopen("input.txt","r",stdin);
    int i,j;
    int T;
    scanf("%d",&T);
    while(T--)
    {
        scanf("%d",&n);
        for(i=0;i<n;i++)
        {
            scanf("%lf",&r[i]);
        }
        sort(r,r+n);
        double ans=1e15;
        do
        {
            double ll,rr;
            p[0]=r[0];
            ll=p[0]-r[0],rr=p[0]+r[0];
            for(i=1;i<n;i++)//枚举和前面的那个圆相切
            {
                p[i]=p[i-1]+2.0*sqrt(r[i-1]*r[i]);
                for(j=0;j<i;j++)
                {
                    p[i]=max(p[i],p[j]+2.0*sqrt(r[i]*r[j]));//确定某个位置的圆心位置,2.0*sqrt(r[i]*r[j])是计算当某个圆与其前面的圆相切是的情况x的距离
                }
                ll=min(p[i]-r[i],ll);//确定左边的位置
                rr=max(p[i]+r[i],rr);//确定右边的位置
            }
            ans=min(ans,rr-ll);//选择最小的排列
        }while(next_permutation(r,r+n));
        printf("%.3lf\n",ans);
    }
    return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值