[CF] 8C Looking for Order

状压模板题 CF难度2000? 我得好好了解一下CF的难度机制了

反正CF的难度比洛谷真实就好了

Code

#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#define N 25
#define INF 0x3f3f3f3f
using namespace std;
inline int read() {
    int x=0,f=1; char ch=getchar();
    while(ch<'0' || ch>'9') { if(ch=='-') f=-1; ch=getchar(); }
    while(ch>='0'&&ch<='9') { x=(x<<3)+(x<<1)+(ch^48); ch=getchar(); }
    return x * f;
}
int n;
int x[N],y[N];
int g[N][N];
int f[1<<N],pre[1<<N];  //状压dp 
void print(int u) {
    printf("0 ");
    if(u == 0) return;
    int bit = u ^ pre[u];   //拿出这两个数 
    for(int i=1;i<=n;++i)
        if(bit & (1<<(i-1)))
            printf("%d ",i);
    print(pre[u]);
}
int main()
{
    x[0] = read(), y[0] = read(); n = read();
    for(int i=1;i<=n;++i)
        x[i] = read(), y[i] = read();
    memset(g, 0x3f, sizeof(g));
    for(int i=0;i<=n;++i)
        for(int j=0;j<=n;++j)
            g[i][j] = g[j][i] = (x[i]-x[j])*(x[i]-x[j]) + (y[i]-y[j])*(y[i]-y[j]);
    memset(f, 0x3f, sizeof(f));
    int maxn = (1<<n)-1;
    f[0] = 0;
    for(int S=0;S<=maxn;++S) {  //state
        if(f[S] == INF) continue;
        for(int i=1;i<=n;++i) {
            if(S & (1<<(i-1))) continue;
            for(int j=1;j<=n;++j) {
                if(S & (1<<(j-1))) continue;
                int x = S | (1<<(i-1)) | (1<<(j-1));
                int y = f[S] + g[0][i] + g[i][j] + g[j][0];
                if(y < f[x]) {
                    f[x] = y;
                    pre[x] = S;
                }
            }
            break;
        }
    }
    printf("%d\n",f[maxn]);
    print(maxn);
    return 0;
}
全部评论

相关推荐

感觉今年拿到大厂实习offer的人很多,光是身边同学室友都是好几个offer。由此可见,秋招得有多卷
小浪_Coding:必须卷的起飞, 应该比25更卷一点, 25已经是哀声一片了, 26会更难一点, 现在还有`很多25未找到的
点赞 评论 收藏
分享
05-12 11:09
已编辑
门头沟学院 后端
已注销:没必要放这么多专业技能的描述。这些应该是默认已会的,写这么多行感觉在凑内容。项目这块感觉再包装包装吧,换个名字,虽然大家的项目基本都是网上套壳的,但是你这也太明显了。放一个业务项目,再放一个技术项目。技术项目,例如中间件的一些扩展和尝试。
点赞 评论 收藏
分享
认真搞学习:28小登的建议,投算法岗不要写什么物理竞赛,互联网+,多写点项目,用什么算法做了什么。还有本科算法是不可能的开发你这个也没有项目啊
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务