Codeforces 8C 状压DP

时间:2022-09-17 00:09:27

题意:有个人想收拾行李,而n个物品散落在房间的各个角落里(n < 24)。现在给你旅行箱的坐标(人初始在旅行箱处),以及n个物品的坐标,你一次只能拿最多两个物品,并且拿了物品就必须放回旅行箱,不能暂时放在地上。问最小的花费是多少?花费是笛卡尔距离的平方。

思路一看n 只有24,应该很容易想到要用状压DP. 那么dp[i]表示i状态并且回到原点的最小花费。那么就暴力枚举拿1个或两个物品放回原点,然后转移就行了。需注意,这个题目中拿物品的顺序对答案无影响,比如先拿1号,再拿2号和先拿2号,再拿1号的花费是一样的。然后满怀欣喜的交了一发,TLE了。。。。我们对题目的性质发掘的不够,既然枚举的时候拿物品的顺序对答案没影响,那么我们状态转移的时候顺序改变对答案没影响。比如现在有1, 2, 3, 4这4个物品没有选,那么先选1, 2再选3,4和先选3,4再选1, 2答案是一样的。所以我们枚举的时候,找到与之前没选过的最靠前的一个,再找出与这个对应的其它状态去更新就可以了。

代码:

#include <bits/stdc++.h>
#define pii pair<int, int>
using namespace std;
const int maxn = 30;
int dis(pii x, pii y) {
return (x.first - y.first) * (x.first - y.first) + (x.second - y.second) * (x.second - y.second);
}
int dp[1 << 24], pre[1 << 24];
pii s, a[maxn];
int n;
int cost[30][30];
void print(int now) {
if(now == 0) {
printf("0 ");
return;
}
print(now ^ pre[now]);
for (int i = 0; i < n; i++) {
if((pre[now] >> i) & 1)
printf("%d ", i + 1);
}
printf("0 ");
}
int main() {
scanf("%d%d",&s.first, &s.second);
scanf("%d", &n);
for (int i = 0; i < n; i++) {
scanf("%d%d", &a[i].first, &a[i].second);
}
for (int i = 0; i < n; i++)
for (int j = 0; j < n; j++) {
// int now = (1 << i) | (1 << j);
// re.push_back(now);
int tmp1 = dis(s, a[i]);
if(i != j) {
tmp1 += dis(a[i], a[j]);
tmp1 += dis(a[j], s);
} else {
tmp1 += dis(a[i], s);
}
//dist.push_back(tmp1);
cost[i][j] = tmp1;
}
memset(dp, 0x3f, sizeof(dp));
dp[0] = 0;
for (int i = 0; i < (1 << n); i++) {
for (int j = 0; j < n; j++) {
if((i >> j) & 1) continue;
for (int k = j; k < n; k++){
if((i >> k) & 1) continue;
int now = (1 << j) | (1 << k);
if(dp[i | now] > dp[i] + cost[j][k]) {
dp[i | now] = min(dp[i | now], dp[i] + cost[j][k]);
pre[i | now] = now;
}
}
break;
}
}
printf("%d\n", dp[(1 << n) - 1]);
print((1 << n) - 1);
}

  

Codeforces 8C 状压DP的更多相关文章

  1. Codeforces 678E 状压DP

    题意:有n位选手,已知n位选手之间两两获胜的概率,问主角(第一个选手)最终站在擂台上的概率是多少? 思路:一看数据范围肯定是状压DP,不过虽然是概率DP,但是需要倒着推:我们如果正着推式子的话,初始状 ...

  2. Codeforces 1215E 状压DP

    题意:给你一个序列,你可以交换序列中的相邻的两个元素,问最少需要交换多少次可以让这个序列变成若干个极大的颜色相同的子段. 思路:由于题目中的颜色种类很少,考虑状压DP.设dp[mask]为把mask为 ...

  3. CodeForces 11D&lpar;状压DP 求图中环的个数&rpar;

    Given a simple graph, output the number of simple cycles in it. A simple cycle is a cycle with no re ...

  4. codeforces 1185G1 状压dp

    codeforces 1185G1. Playlist for Polycarp (easy version)(动态规划) 传送门:https://codeforces.com/contest/118 ...

  5. Codeforces 1155F 状压DP

    题意:给你一张图,问最少保留多少条边,使得这张图是边双联通分量. 思路:如果一个点集中的点已经是边双联通分量,那么从这个点集中的点x出发,经过若干个不是点集中的点,回到点集中的点y(x可能等于y),那 ...

  6. Codeforces - 71E 状压DP

    参考官方题解 #include<bits/stdc++.h> #define rep(i,j,k) for(register int i=j;i<=k;i++) #define rr ...

  7. codeforces 8C&period; Looking for Order 状压dp

    题目链接 给n个物品的坐标, 和一个包裹的位置, 包裹不能移动. 每次最多可以拿两个物品, 然后将它们放到包里, 求将所有物品放到包里所需走的最小路程. 直接状压dp就好了. #include &lt ...

  8. 【题解】codeforces 8c Looking for Order 状压dp

    题目描述 Lena喜欢秩序井然的生活.一天,她要去上大学了.突然,她发现整个房间乱糟糟的--她的手提包里的物品都散落在了地上.她想把所有的物品都放回她的手提包.但是,这里有一点问题:她一次最多只能拿两 ...

  9. codeforces Diagrams &amp&semi; Tableaux1 (状压DP)

    http://codeforces.com/gym/100405 D题 题在pdf里 codeforces.com/gym/100405/attachments/download/2331/20132 ...

随机推荐

  1. div元素抓取

    var files = $(".button").find("input[type='image']"); files.each(function() { $( ...

  2. dWebBrowser常用知识点

    1.webbrowser调用的就是本机IE,并且webbrowser默认就是运行在IE7 mode下,除非你改变它. 2.不装IE,无法用webbrowser. 3.设置WebBrowser在IE9 ...

  3. &lt&semi;九&gt&semi;面向对象分析之UML核心元素之设计类,类,属性,方法,可见性

    设计类

  4. &lbrack;CSS&rsqb;&lbrack;转载&rsqb;内层div的margin-top影响外层div

    参考 内层div的margin-top影响外层div——引出外边距合并 div嵌套导致子区域margin-top失效不起作用的解决方法 我使用的是在外层的div中添加 border: 1px soli ...

  5. AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA

    http://quote.eastmoney.com/center/list.html#28003501_0_2 http://bbs.tianya.cn/post-53726-21098-1.sht ...

  6. yii 缓存探究

    1.在配置文件中 //在权威指南上是'cache' 其实可以根据不同的缓存组件起不同的名称 //memcache缓存 'memcache' => array( 'class' => 'sy ...

  7. &lbrack;ZETCODE&rsqb;wxWidgets教程六:事件处理

    本教程原文链接:http://zetcode.com/gui/wxwidgets/events/ 翻译:瓶哥 日期:2013年12月7号星期六 邮箱:414236069@qq.com 主页:http: ...

  8. &lbrack;JQuery&rsqb;JQuery选择器引擎Sizzle

    写代码过程中,发现使用JQuery选择器时,$('div.tooltip')和$('.tooltip')的结果不一样,怀疑和选择器的代码逻辑有关(事后证明是代码的低级错误,但是从查找原因的过程中,学到 ...

  9. 关于ALTERA生成IP核卡住

    最近搞fft,用的quartus13.1版本,发现quartus和modelism存在各种各样的坑啊,fftIP核大家可能也遇到过ip核 生成到一半就卡住的问题,之前我是通过换系统解决的,但是好景不长 ...

  10. 通过设置ie的通过跨域访问数据源,来访问本地服务

    1.首先设置通过域访问数据源 设置通过域访问数据源 2.javascript脚本ajax使用本地服务登录(评价,人证的类似)接口 <html> <head> <scrip ...