P2210 Haywire

题目描述

Farmer John有N只奶牛,(4 <= N <= 12,其中N是偶数).

他们建立了一套原生的系统,使得奶牛与他的朋友可以通过由干草保护的线路来进行对话交流.

每一头奶牛在这个牧场中正好有3个朋友,并且他们必须把自己安排在一排干草堆中.

一条长L的线路要占用刚好N堆干草来保护线路.

比如说,如果有两头奶牛分别在草堆4与草堆7中,并且他们是朋友关系,那么我们就需要用3堆干草来建造线路,使他们之间能够联系.

假设每一对作为朋友的奶牛都必须用一条单独的线来连接,并且我们可以随便地改变奶牛的位置,请计算出我们建造线路所需要的最少的干草堆.

输入输出格式

输入格式:

第1行:一个整数N. 为了方便,我们给奶牛用1~N的数字进行编号.

第2..1+N: 每一行都有三个在1~N中的整数. 第i+1行的数字代表着第i头奶牛的三个朋友的编号。显然,如果奶牛i是奶牛j的三个朋友之一,那么奶牛j也是奶牛i的三个朋友之一.

输出格式:

一个整数,代表着建造线路需要的干草堆数量的最小值.

输入输出样例

输入样例#1: 复制

6
6 2 5
1 3 4
4 2 6
5 3 2
4 6 1
1 5 3
输出样例#1: 复制

17

说明

样例解释: 奶牛最好的排列是6, 5, 1, 4, 2, 3, 这个时候我们只需要17个单位的干草堆.

#include<bits/stdc++.h>

#define N 20

using namespace std;
int n,m,ans,cnt;
int a[N],vis[N],dis[N][N],fri[N][]; inline int read()
{
int x=,f=;char c=getchar();
while(c>''||c<''){if(x=='-')f=-;c=getchar();}
while(c>=''&&c<=''){x=x*+c-'';c=getchar();}
return x*f;
} inline int abs_(int a){return a<?-a:a;} void calc()
{
static int pos[N];
for(int i=;i<=n;i++) pos[a[i]]=i;
int tot=;memset(dis,,sizeof dis);
for(int i=;i<=n;i++) for(int j=;j<=;j++)
{
if(dis[i][fri[i][j]] || dis[fri[i][j]][i]) continue;
dis[i][fri[i][j]]=dis[fri[i][j]][i]=;tot+=abs_(pos[i]-pos[fri[i][j]]);
}ans=min(ans,tot);
} void dfs(int k)
{
for(int i=;i<=n;i++)
{
if(!vis[i])
{
vis[i]=;a[k]=i;
if(k==n) calc();
dfs(k+);
vis[i]=;
}
}
} int main()
{
//freopen("ly.in","r",stdin);
n=read();
for(int i=;i<=n;i++) for(int j=;j<=;j++)
fri[i][j]=read();
ans=0x3f3f3f3f;dfs();
printf("%d\n",ans);
return ;
}

49暴力dfs

/*
nowtot:当前总距离;
links:已经访问的所有奶牛中,有多少路线没有找到,(即某奶牛的朋友还没有找到);
remain:已经访问的所有奶牛中,没有找到的路线的长度总和,(是当前,并不是所有);
因为每条路线至少是1,所以我们假定所有没找到的路线开始都为1; 每次,remain+links,即当前位置,还没有找到的所有路线都+1(显然);
因此remain是我们的方案的下限,即最小的估值(不可能更小了); 其实,这只是个“随机”值,但这个随机值不会让答案错误;
*/
#include<bits/stdc++.h> #define N 20 using namespace std; int fr[N][],a[N],pos[N];
int n,ans,cnt;
bool vis[N]; void dfs(int x,int nowtot,int links,int remain)
{ if(x==n+) ans=min(ans,nowtot);
if(remain+nowtot >= ans) return;//最优化剪枝 for(int i=;i<=n;i++)
{
if(!pos[i])
{
int new_link=,sum=;//每个奶牛开始有三个朋友;
pos[i]=x;//第i个奶牛放在x上;
for(int j=;j<=;j++)
{
if(pos[fr[i][j]]!=)
{
sum+=abs(x-pos[fr[i][j]]);//发现这条路线已经确定;
new_link-=;//friend路线-1,当前奶牛同样-1,总的减2;
}
}
dfs(x+,nowtot+sum,links+new_link,remain+(links+new_link)-sum);
pos[i]=;
}
}
return;
} int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++)for(int j=;j<=;j++)
scanf("%d",&fr[i][j]);
ans=0x3f3f3f3f; dfs(,,,);
printf("%d\n",ans);
return ;
}

P2210 Haywire(A*)的更多相关文章

  1. P2210 Haywire

    P2210 Haywire 模拟退火练手题 #include<cmath> #include<ctime> #include<cstdio> #include< ...

  2. [洛谷P2210]Haywire

    题目大意:有$n(n\leqslant12)$个数,每个数和其他三个数连边,求一个排列,使得边的长度最小 题解:状压$DP$,$f_{i,j}$表示当前确定的数状态为$i$,有$j$条边起点被确定终点 ...

  3. luogu P2210 Haywire

    [返回模拟退火略解] 题目描述 一数轴上有 nnn 个点,有 nnn 个环,求一种组合方案,使得所有边长度和最小. Solution 2210\text{Solution 2210}Solution  ...

  4. Luogu P2210 Haywire 题解

    其实这题吧...有一种玄学解法 这题的要求的就是一个最小化的顺序 那么,我们就不进想到了一种显然的写法 就是random_shuffle 什么?这不是乱搞的非正解吗 然而,正如一句话说的好 一个算法, ...

  5. ZJOI2019一轮停课刷题记录

    Preface 菜鸡HL终于狗来了他的省选停课,这次的时间很长,暂定停到一试结束,不过有机会二试的话还是可以搞到4月了 这段时间的学习就变得量大而且杂了,一般以刷薄弱的知识点和补一些新的奇怪技巧为主. ...

  6. Haywire

    还是模拟退火乱搞. 不过考虑记录一下在整个退火过程中的最优答案. 而不是只看最后剩下的解. 退火是一个随机算法,他有很大的几率能跳到最优解,但也很有可能从最优解跳出去. 所以要记录答案. Haywir ...

  7. 【LuoguP2210 USACO】 Haywire

    这种答案跟序列排列顺序有关的,n比较小的(稍微大一点的也可以),求最优解的,一般都可以随机化过 随机化不一定是模拟退火或是什么遗传蚁群 哪怕只是直接随机化一个序列,只要你随机的次数够多,它都能找到正解 ...

  8. 洛谷P2210题解

    题面 模拟退火练手好题. 对于这个题,一般有两种解法: 每次随机两个数交换. 每次直接打乱数组. 两个方法都可以过,我写了第一种,因为不想用stl. 代码

  9. jQ1.5源码注释以及解读RE

    jQ作为javascript的库( ▼-▼ ), 尽善尽美, 代码优美,  值得学习.  这一周平常上班没啥事也看jQ1.5的代码, 今天周六差不多看完了(Sizzle部分还没看), 重新看了一下, ...

随机推荐

  1. windows上安装mysql

    安装mysql后 命令行闪退 查看服务 也没有MySQL服务启动 你安装了mysql没有,没有就先安装,安装好mysql以后,在bin目录下有个mysqld.exe,运行这个程序就可以添加mysql服 ...

  2. 【.Net 学习系列】-- EF Core实践(Code First)

    一.开发环境: vs2015, .Net Framework 4.6.1 二.解决方案: 新建一个控制台应用程序 添加引用:Microsoft.EntityFrameworkCore.SqlServe ...

  3. Linux面试题完整修订附加答案

    册一: 1.Linux挂载Winodws共享文件夹 第一步:先在Windows上创建一个共享目录        Windows系统IP是172.16.18.56;共享文件夹:E:\test       ...

  4. CentOS 7下安装Logstash ELK Stack 日志管理系统(下)

    修改防火墙,对外开放tcp/5601 [root@elk elk]# firewall-cmd --permanent --add-port=5601/tcpSuccess[root@elk elk] ...

  5. libevent多线程使用事项

    转 http://www.cnblogs.com/Seapeak/archive/2010/04/08/1707807.html 在linux平台上使用c开发网络程序的同志们一般情况下都对鼎鼎大名的l ...

  6. 3.2.1 配置构建Angular应用——简单的笔记存储应用——编辑功能

    本节我们会接着上节课的内容,继续来完成使用Angular来创建简单的笔记存储应用,上一节课,我们完成了笔记的展示功能,本节课,我们来完成编辑功能. 编辑主要是两个功能:编辑现有的笔记以及创建新笔记.首 ...

  7. 在CentOS上把MySQL从5.5升级到5.6

    在CentOS上把MySQL从5.5升级到5.6 摘要:本文记录了在CentOS 6.3上,把MySQL从5.5.28升级到5.6.19的过程. 1. 概述 在我做的一个项目中,最近我对生产服务器上的 ...

  8. Java使用三种不同循环结构对1+2+3+...+100 求和

    ▷//第一种求法,使用while结构 /** * @author 9527 * @since 19/6/20 */ public class Gaosi { public static void ma ...

  9. 设置ArcGIS的数据源

    我从别的地方拿到一份现成的地图文档(*.mxd),在该服务器上运行得好地地,图文并茂,但用我自己机器的arcMap打开就一片空白,啥都没有. 看左边的各个图层目录,图标上都有个粉红色的惊叹号,醒悟过来 ...

  10. Codeforces 768 E. Game of Stones 博弈DP

    E. Game of Stones   Sam has been teaching Jon the Game of Stones to sharpen his mind and help him de ...