zoukankan      html  css  js  c++  java
  • Lightoj1018 【状压DP】

    题意:

    给你一个坐标系,坐标系上有N个点,然后让你用最少的线,把这些点全部连起来;


    思路:

    (1+15)*15/2=90条线;
    然后线上有哪些点就可以知道;
    然后按照线上点的个数排序,然后删掉这个线,看一下是否满足;
    但是这种想法不就是每次拿点最多的线,然后判断是否满足,这样的话很明显就不行= =
    所以DP。

    N<=15很明显可以状压,所以想到状压DP。
    每个状态表示有几个点还没有选,然后如果点数<=2,那么答案  dp[now_status]=dp[pre_status]+1;
    点用二进制数表示状态,那么我们用线存的也是一个值,表示该线上有多少个点就好了(这个才是状压DP的精髓吧,一旦结果是状压,那么条件也是状压)

    用line[i][j] 表示i , j上有多少个点,line[i][j] | = (1<<id);

    每次状态dp[now_status]=dp[now_status&(~line[i][j])](意思就是在之前那个没有把这条线加了的点的情况转移过来)+1(加这条线以后,线多一条);

    感觉也是记忆化搜索写的方便;


  • 相关阅读:
    全选。取消
    Js获取下拉框的值和文本select
    回调函数
    js判断浏览器
    JS获取活动区域高和宽
    判断身份证
    Linux驱动架构之pinctrl子系统分析(一)
    Android的开机启动流程
    Android中getprop命令的使用
    C运算符优先级和结合性
  • 原文地址:https://www.cnblogs.com/keyboarder-zsq/p/6216750.html
Copyright © 2011-2022 走看看