题意:

     给出房间的宽度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 天平难题的更多相关文章

  1. LA3403天平难题(4个DFS)

    题意:      给出房间的宽度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. 深入super,看Python如何解决钻石继承难题 【转】

    原文地址 http://www.cnblogs.com/testview/p/4651198.html 1.   Python的继承以及调用父类成员 python子类调用父类成员有2种方法,分别是普通 ...

  7. 探讨webapp的SEO难题(上)

    前言 网络蜘蛛无法解析javascript,至少百度是不能的,神马搜索差的更远,而我们的webapp的渲染展示完全由javascript驱动 所以蜘蛛访问webapp页面会得到一个白页面,比如,我们期 ...

  8. hduoj 1251 统计难题

    http://acm.hdu.edu.cn/showproblem.php?pid=1251 统计难题 Time Limit: 4000/2000 MS (Java/Others)    Memory ...

  9. UVa 12166 修改天平

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

随机推荐

  1. 【转载】markdown数学常用公式箭头符号

    来源1:https://www.jianshu.com/p/3f01c5658356 来源2:https://blog.csdn.net/smstong/article/details/4434063 ...

  2. java 流程控制学习

    https://www.kuangstudy.com/course 用户交互Scanner import java.util.Scanner; public class Demo01 { public ...

  3. 深入浅出新一代跨平台抓包&调式利器Fiddler Everywhere

    什么是Fiddler Everywhere? Fiddler Everywhere is a web debugging proxy for macOS, Windows, and Linux. Ca ...

  4. 漏洞复现-ActiveMq反序列化漏洞(CVE-2015-5254)

          0x00 实验环境 攻击机:Win 10 靶机也可作为攻击机:Ubuntu18 (docker搭建的vulhub靶场) 0x01 影响版本 Apache ActiveMQ 5.13.0之前 ...

  5. python实现通过URL下载图片到本地服务器

    import os import urllib.request image_url = 'http://img.jingtuitui.com/759fa20190115144450401.jpg' f ...

  6. PTA 带头结点的链式表操作集

    6-2 带头结点的链式表操作集 (20 分)   本题要求实现带头结点的链式表操作集. 函数接口定义: List MakeEmpty(); Position Find( List L, Element ...

  7. 003-Java中的变量和数据类型

    @ 目录 一.变量 1.什么变量 2.变量的三要素 3.变量的命名规范 4.变量的分类 5.变量的作用域 6.变量的注意事项 二.数据类型 1.什么是数据类型 2.数据类型有什么用 3.数据类型的分类 ...

  8. 使用 Elastic 技术栈构建 Kubernetes全栈监控

    以下我们描述如何使用 Elastic 技术栈来为 Kubernetes 构建监控环境.可观测性的目标是为生产环境提供运维工具来检测服务不可用的情况(比如服务宕机.错误或者响应变慢等),并且保留一些可以 ...

  9. 如何在CMDB中落地应用的概念?

    如何在CMDB中落地应用的概念? 我们前面讲了应用是整个微服务架构体系下运维的核心,而CMDB又是整个运维平台的基石.今天我就讲讲在CMDB中如何落地应用这个核心概念,以及如何建立应用集群分组的思路. ...

  10. [状压DP]车II

    车 I I 车II 车II 题目描述 有一个 n ∗ m n*m n∗m的棋盘 ( n . m ≤ 80 , n ∗ m ≤ 80 ) (n.m≤80,n*m≤80) (n.m≤80,n∗m≤80)要 ...