嗯?这题竟然是个绿题。

这个题真的不(很)难,我们只是不会计算2点之间的距离,他还给出了公式,这个就有点……

我们直接套公式去求出需要的值,然后普通的状压dp就可以了。

是的状压dp。

这个题的数据加强了,早已经不是搜索可以驾驭的了。

搜索的效率实在是有点低,我来算一个不准的效率,搜索的效率应该是O(n!)。应该是吧。

状压dp只需要短短的O(2^n*n*n就可以了)。状态共有2^n*n个,每次查找下一步需要O(n)的效率,所以状压dp的效率是O(2^n*n*n)。

状压dp用一个二进制数表示哪个奶酪曾经吃过,我们先看看这些二进制数的基本操作:不知道与,或,异或运算的可以百度一下。

第一种操作,查询第i个奶酪有没有吃过。

x表示现在奶酪的情况(2进制数)

我们要判断第i个奶酪有没有被吃

if((x&(1<<i-1))==0)

这样写就可以啦。其中&的意思是按位与运算,就是说在2进制下,2位同时为1,结果才为1,也就是说,如果第i个奶酪被吃掉了,x那一位就是1,按位与运算后的结果也是1,如果按位与运算后的结果是0,第i个奶酪就没有被吃掉。

第二种操作,吃掉第i个奶酪后,x会变成什么样子?

x=x|(1<<i-1)

这样写,|是按位或运算,就是在二进制里,2位有一个为1,结果为1,1<<i-1的第i位是1,和x进行按位或运算就让x的第i位也变成1了。

做这个题只需要这两个操作,剩下的操作有兴趣的同学可以去百度一下。

接下来就是代码了:

#include<iostream>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<cstdio>
using namespace std;
double a[20],b[20],shu=999999.0;//初始化
double dp[40000][20];
double sz[20][20];//sz[i][j]是表示第i个奶酪到第j个奶酪有多远。
long long n;
int main()
{
scanf("%lld",&n);
for(int i=0;i<(1<<n);i++)
{
for(int j=1;j<=n;j++)
{
dp[i][j]=999999.0;//还是初始化
}
}
for(int i=1;i<=n;i++)
{
cin>>a[i]>>b[i];
}
a[0]=0;//依然是初始化
b[0]=0;//因为老鼠一开始在0,0的位置。
for(int i=0;i<=n;i++)
{
for(int j=0;j<=n;j++)
{
sz[i][j]=sqrt((a[i]-a[j])*(a[i]-a[j])+(b[i]-b[j])*(b[i]-b[j]));//公式摆着呢,题目给了。
}
}
for(int i=1;i<=n;i++)//1<<i-1是把1左移i-1位,在二进制就是第i位是1。dp[i][j]中的i表示现在的情况(二进制数),j表示现在在哪个奶酪哪里。dp[i][j]的值就是达成这个局势最少走多远。
{
dp[1<<i-1][i]=sz[0][i];
}
for(int i=1;i<=(1<<n)-1;i++)//所有情况,也就是n个1,也就是(1<<n)-1。
{
for(int j=1;j<=n;j++)//在第j个奶酪处。
{
if(dp[i][j]!=999999)//这种情况不可能,比如i=1,j=2;
{
for(int k=1;k<=n;k++)//他的起始点出现过,搜索还能走到哪个奶酪处。
{
if((i&(1<<k-1))==0)//这个奶酪处没来过。
{
dp[i|(1<<k-1)][k]=min(dp[i|(1<<k-1)][k],dp[i][j]+sz[j][k]);//来这个奶酪处。判断一下这样走是不是最近的。
}//有2种可能,第一,之前来过,而且走的距离比这次小,第二种,这次走的距离加上目前位置到第k个奶酪的距离是最短的。反正我们直接找最短的就好。
}
}
}
}
for(int i=1;i<=(1<<n)-1;i++)
{
for(int j=1;j<=n;j++)
{
if(i==(1<<n)-1)
{
shu=min(shu,dp[i][j]);//这里为了方便查找错误写的,可以更优化一点,但没必要。
}
}
}
printf("%.2f",shu);//输出。
return 0;
}

好了,这个题目就这么愉快的讲完了。

P1433 吃奶酪(洛谷)状压dp解法的更多相关文章

  1. 吃奶酪 洛谷 p1433

    题目描述 房间里放着n块奶酪.一只小老鼠要把它们都吃掉,问至少要跑多少距离?老鼠一开始在(0,0)点处. 输入输出格式 输入格式: 第一行一个数n (n<=15) 接下来每行2个实数,表示第i块 ...

  2. P6085-[JSOI2013]吃货JYY【状压dp,欧拉回路】

    正题 题目链接:https://www.luogu.com.cn/problem/P6085 题目大意 \(n\)个点的一张无向图,有\(k\)条必走边,\(m\)条其他边,求从\(1\)出发经过必走 ...

  3. 最短Hamilton路径-状压dp解法

    最短Hamilton路径 时间限制: 2 Sec  内存限制: 128 MB 题目描述 给定一张 n(n≤20) 个点的带权无向图,点从 0~n-1 标号,求起点 0 到终点 n-1 的最短Hamil ...

  4. 有关状压DP

    [以下内容仅为本人在学习中的所感所想,本人水平有限目前尚处学习阶段,如有错误及不妥之处还请各位大佬指正,请谅解,谢谢!] 引言 动态规划虽然已经是对暴力算法的优化,但在某些比较特别的情况下,可以通过一 ...

  5. 洛谷 P1433 吃奶酪 状压DP

    题目描述 分析 比较简单的状压DP 我们设\(f[i][j]\)为当前的状态为\(i\)且当前所在的位置为\(j\)时走过的最小距离 因为老鼠的坐标为\((0,0)\),所以我们要预处理出\(f[1& ...

  6. 洛谷P3959 宝藏(NOIP2017)(状压DP,子集DP)

    洛谷题目传送门 Dalao的题解多数是什么模拟退火.DFS剪枝.\(O(3^nn^2)\)的状压DP之类.蒟蒻尝试着把状压改进了一下使复杂度降到\(O(3^nn)\). 考虑到每条边的贡献跟它所在的层 ...

  7. 【题解】洛谷P3959 [NOIP2017TG] 宝藏(状压DP+DFS)

    洛谷P3959:https://www.luogu.org/problemnew/show/P3959 前言 NOIP2017时还很弱(现在也很弱 看出来是DP 但是并不会状压DP 现在看来思路并不复 ...

  8. 【题解】洛谷P2704 [NOI2001] 炮兵阵地(状压DP)

    洛谷P2704:https://www.luogu.org/problemnew/show/P2704 思路 这道题一开始以为是什么基于状压的高端算法 没想到只是一道加了一行状态判断的状压DP而已 与 ...

  9. 【题解】洛谷P1896 [SCOI2005] 互不侵犯(状压DP)

    洛谷P1896:https://www.luogu.org/problemnew/show/P1896 前言 这是一道状压DP的经典题 原来已经做过了 但是快要NOIP 复习一波 关于一些位运算的知识 ...

随机推荐

  1. Beta冲刺<6/10>

    这个作业属于哪个课程 软件工程 (福州大学至诚学院 - 计算机工程系) 这个作业要求在哪里 Beta冲刺 这个作业的目标 Beta冲刺--第六天(05.24) 作业正文 如下 其他参考文献 ... B ...

  2. shell编程之系统环境变量

    点后面加上空格+配置文件等价于source 配置文件 常见的系统环境变量的配置 Bash_profile和.bashrc存在在家目录下,~表示家目录 [root@localhost home]# cd ...

  3. Java工具类—包装类

    Java工具类--包装类 我们都知道,JDK 其实给我们提供了很多很多 Java 开发者已经写好的现成的类,他们其实都可以理解成工具类,比如我们常见的集合类,日期相关的类,数学相关的类等等,有了这些工 ...

  4. 超简单集成HMS Scan Kit扫码SDK,轻松实现扫码购

    前言   在前面的文章中,我们向大家介绍了HMS Scan Kit 的快速集成方法以及HMS Scan Kit和其他开源扫码工具的竞争力对比分析,如果没有看到也没关系,文章下方的往期链接中有文章入口. ...

  5. JS控制滚动条的位置

    转载▼http://blog.sina.com.cn/s/blog_4481a3460100rwwu.html     JS控制滚动条的位置:window.scrollTo(x,y); 竖向滚动条置顶 ...

  6. 记一次服务器被植入挖矿木马cpu飙升200%解决过程

    线上服务器用的是某讯云的,欢快的完美运行着Tomcat,MySQL,MongoDB,ActiveMQ等程序.突然一则噩耗从前线传来:网站不能访问了. 此项目是我负责,我以150+的手速立即打开了服务器 ...

  7. python数据结构-最全的六种排序

    1.冒泡排序: 比较相邻的元素,如果第一个比第二个大,那就交换位置 让大的元素跟下一个相邻的元素作比较,如果大于交换位置 对所有元素重复以上步骤(除了最后一个),直到没有任何一个需要作对比 2.选择排 ...

  8. Python线程池与进程池

    Python线程池与进程池 前言 前面我们已经将线程并发编程与进程并行编程全部摸了个透,其实我第一次学习他们的时候感觉非常困难甚至是吃力.因为概念实在是太多了,各种锁,数据共享同步,各种方法等等让人十 ...

  9. 美国6w刀的远程工作高级工程师职位,说下在线评估, 倒在第一阶段, 认知能力测试?智商不够怎么办?!

    前几天刚被裁员了, 然后在Linkedin上面看到一个crossover的senior software engineer的职位,写的可以remote, 6w刀, 我第一次参加这个公司的这种在线测试, ...

  10. Prince and princess——需要优化的DP

    一个时间效率为o(nlogn)的算法求公共子序列的应用 Prince and princess 题目大意(已翻译 ) 在nxn的棋盘上,王子和公主玩游戏.棋盘上的正方形编号为1.2.3 ... n * ...