题意:

     给出房间的宽度r和每个吊坠的重量wi,设计一个尽量宽但宽度不能超过房间宽度的天平,挂着所有挂坠,每个天平的一段要么挂这一个吊坠,要么挂着另一个天平,每个天平的总长度是1,细节我给出题目中的几个图来方便理解:


思路:

      敲了将近两个小时,数据比较小,也就是说只要找到解决方法,一般就可以直接AC了,首先我们可以搜索枚举天平的状态,就是总的天平的框架的样子,也就是二叉树的样子,这个地方卡了一会才想出来,我们可以直接枚举当天天平上有的点,每一步搜索是在当前天平上已有的点的叶子节点中两种决策,要么增加一个天平,要么不增加,在别的叶子节点上增加天平,总之当前这一步要在一个叶子节点上增加天平,(想想我们画二叉树的时候是不是这样画的),而且每增加一个天平就会在二叉树上增加一个挂坠的数量,一直增加到测试数据给的吊坠的数量,对于每一个枚举得到的二叉树,我们可以知道他一定是n个叶子节点的二叉树,然后我们用一个全排列(也可以写深搜,用全排列是为了不让代码太多,太乱)给这个叶子附上对应的重量,赋完重量之后我们可以再用深搜来给每个非叶子节点到他做儿子和有儿子的距离求出来,这个比较简单(不会可以直接看下面代码),求完距离之后可以用深搜遍历没一条路径,树根的坐标是0,然后往左就-,往右就+得到一个最大和最小的坐标,然后根据坐标差来更新最优值,这个题目我写了三个深搜,一个全排列AC的,感觉实现的有点麻烦,但不知道有没有更省事的,目前百度不到,还有就是有一个比较坑人的地方就是当吊坠只有一个的时候直接输出0,不是-1。

#include<stdio.h>

#include<string.h>

#include<algorithm>

#define N 3000

using namespace std;

typedef struct

{

   double ll ,rr ,ww;

   int mk;

}NODE;

NODE node[N];

int Now[N] ,n ,nn;

double num[10] ,r ,Ans;

double minn ,maxx;

double DFSlr(int now)

{

   if(node[now].mk) return node[now].ww;

   double lsum = DFSlr(now * 2);

   double rsum = DFSlr(now * 2 + 1);

   node[now].ll = rsum / (lsum + rsum);

   node[now].rr = lsum / (lsum + rsum);

   return lsum + rsum;

}

void DFSmm(double v ,int now)

{

   if(node[now].mk)

   {

      if(minn > v) minn = v;

      if(maxx < v) maxx = v;

      return;

   }

   DFSmm(v - node[now].ll ,now * 2);

   DFSmm(v + node[now].rr ,now * 2 + 1);

}

void DFS(int sw ,int sumnode)

{

   if(sw == n)

   {

      int tmpyz[10] ,nowid = 0;

      for(int i = 1 ;i <= sumnode ;i ++)

      if(node[Now[i]].mk) tmpyz[++nowid] = Now[i];

      for(int i = 1 ;i <= nn+1 ;i ++)

      {

         for(int j = 1 ;j <= n ;j ++)

         node[tmpyz[j]].ww = num[j];

         DFSlr(1);

         maxx = -100000 ,minn = 100000;

         DFSmm(0 ,1);

         if(maxx - minn <= r)

         {

            if(Ans < maxx - minn)

            Ans = maxx - minn;

         }        

         next_permutation(num + 1 ,num + n + 1);

       }

      return;

   }

   for(int i = 1 ;i <= sumnode ;i ++)

   {

      if(node[Now[i]].mk)

      {

        node[Now[i]].mk = 0;

        node[Now[i]*2].mk = 1;

        node[Now[i]*2+1].mk = 1;

        Now[sumnode+1] = Now[i]*2;

        Now[sumnode+2] = Now[i]*2+1;

        DFS(sw + 1 ,sumnode + 2);

        node[Now[i]].mk = 1;

        node[Now[i]*2].mk = 0;

        node[Now[i]*2+1].mk = 0;

      }

   }

}

int main ()

{

   int t ,i;

   scanf("%d" ,&t);

   while(t--)

   {

      scanf("%lf" ,&r);

      scanf("%d" ,&n);

      for(nn = i = 1 ;i <= n ;i ++)

      {

         scanf("%lf" ,&num[i]); 

         nn *= i;

      }

      if(n == 1)

      {

         printf("0\n");

         continue;

      }

      memset(node ,0 ,sizeof(node));

      Now[1] = 1 ,Ans = -1;

      node[1].mk = 1;

      DFS(1 ,1);

      printf("%.16lf\n" ,Ans);

   }

   return 0;

}

      

   

   

        

        

        

   

   

         

      

LA3403天平难题(4个DFS)的更多相关文章

  1. LA3403 天平难题

    题意:      给出房间的宽度r和每个吊坠的重量wi,设计一个尽量宽但宽度不能超过房间宽度的天平,挂着所有挂坠,每个天平的一段要么挂这一个吊坠,要么挂着另一个天平,每个天平的总长度是1,细节我给出题 ...

  2. uva1354 天平难题 【位枚举子集】||【huffman树】

    题目链接:https://vjudge.net/contest/210334#problem/G 转载于:https://blog.csdn.net/todobe/article/details/54 ...

  3. UVa 1354 天平难题

    https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...

  4. UVa 1354 天平难题 (枚举二叉树)

    题意: 分析: 其实刚看到这题的时候觉得很难, 以至于结束了第七章然后去做了一遍第六章树的部分.现在再做这题觉得思路并不是太难,因为总共就只有六个结点,那么只要枚举二叉树然后算出天平然后再从叶子往上推 ...

  5. UVa 1354 天平难题 Mobile Computing

    整个题考虑起来 最主要要计算的状态 是树的状态 于是要计算出所有可能挂坠可能组成的树的所有形态 tree 用于保存这些状态 考虑不要重复计算,有一个vis 数组 预处理可以先计算出一棵树的重量,简化计 ...

  6. Codeforces Round #308 (Div. 2) C. Vanya and Scales dfs

    C. Vanya and Scales Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/552/p ...

  7. 【BZOJ】1673: [Usaco2005 Dec]Scales 天平(dfs背包)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1673 bzoj翻译过来的c<=230不忍吐槽......................... ...

  8. UVA - 12166 Equilibrium Mobile (修改天平)(dfs字符串表示的二叉树)

    题意:问使天平平衡需要改动的最少的叶子结点重量的个数. 分析:天平达到平衡总会有个重量,这个重量可以由某个叶子结点的重量和深度直接决定. 如下例子: 假设根结点深度为0,结点6深度为1,若以该结点为基 ...

  9. UVa 12118 检查员的难题(dfs+欧拉回路)

    https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...

随机推荐

  1. 操作系统---IO权限管理和敏感指令

    简化版 使用IOPL设置一个特权级的用户程序对所有端口的访问权限,使用I/O位图对一个特权级的用户程序设置个性化的端口访问权限(能访问部分端口.不能访问另外的端口). 用户程序的CPL<IOPL ...

  2. 【白话科普】CDN & 游戏加速器,两者是一个原理吗?

    说起加速,大家可能就会联想到"游戏加速"之类的场景,而说到现在流行的云服务加速,则离不开 CDN 这个词.那么 CDN 和游戏加速器是同一种东西么?从效果上看两者都是为了" ...

  3. Linux下查看文件内容的几种常用命令

    [常用] 1,cat     由第一行开始显示内容,并将所有内容输出 cat的功能是将文件从第一行开始连续的将内容输出在屏幕上.但是cat并不常用,原因是当文件大,行数比较多时,屏幕无法全部容下时,只 ...

  4. 追洞小组 | 实战CVE-2020-7471漏洞

    出品|MS08067实验室(www.ms08067.com) 本文作者:守拙(Ms08067实验室追洞小组成员) 一.漏洞名称: 通过StringAgg(分隔符)的潜在SQL注入漏洞 二.漏洞编号: ...

  5. WPF 基础 - 属性

    1. CLR 属性 .Net Framework 中的属性又称为 CLR 属性,是对 private 字段的安全访问包装. 使用 ILSpy 反编译器可以看到 C# 中代码的属性的编译结果是 set. ...

  6. FreeBSD 乃至开源界中的孔乙己 再论苦难哲学之一

    在许多狂热的FreeBSD 粉丝里,他们甚至不允许别人把FreeBSD写作freebsd,要和你强调,F和BSD都是大写的.还说这是什么尊重之类的东西.大抵和孔乙己的茴香豆的茴的有四种写法一样吧:&q ...

  7. 推荐一款小众且好用的 Python 爬虫库 - RoboBrowser

    1. 前言 大家好,我是安果! 今天推荐一款小众轻量级的爬虫库:RoboBrowser RoboBrowser,Your friendly neighborhood web scraper!由纯 Py ...

  8. 【odoo14】第六章、管理模块数据

    本章代码可在原作者github下载 使用外部ID及命名空间 外部ID及XML ID用于标记记录.到目前为止,我们在视图.菜单及动作中接触了XML IDs.本节我们将进一步了解什么是XML ID. 步骤 ...

  9. 2019 GDUT Rating Contest I : Problem H. Mixing Milk

    题面: H. Mixing Milk Input file: standard input Output file: standard output Time limit: 1 second Memory ...

  10. python-顺序队列的实现

    class seqqueue(object): 8 def __init__(self,maxsize): 9 self.maxsize = maxsize 10 self.queueelem = [ ...