题意:

      给你一个n*n的矩阵,然后让咱们构造另一个n*n的矩阵,构造的矩阵有如下要求,

1.X12+X13+...X1n=1.

2.X1n+X2n+...Xn-1n=1.

3.for each i (1<i<n), satisfies ∑Xki (1<=k<=n)=∑Xij (1<=j<=n).

思路:

      感觉这个思路很奇葩啊,看了网上好多解释,但是很失望啊,几乎所有人说的都一样啊,一样到几乎不差一个字,我就 呵呵了,说实话这个题目我不是很理解,可以说现在并不是很明白,但是我可以说下我现在对他们的做法的一些理解,可能不全面,也可能有错误,希望路过的大牛指点,首先据说这是个0/1规划问题,我只知道0/1分数规划,不知道什么是0/1规划,而且具我的了解这个题目跟0/1分数规划没啥关系,我们现在就往图论上靠一下,首先虚拟出n个点来,记住这n个点不是行,也不是列,把题目给的矩阵就单独当成是一些数据,一些点之间的距离,不要去往矩阵上想,这样便于理解,然后分析它给的三个条件:


1.X12+X13+...X1n=1. 这个条件可以理解成是点1的出度为1,因为1会选择也只能选择一个点连出去,这样的话1的出度为0.


2.X1n+X2n+...Xn-1n=1. 同上,n的入度为0.

3.for each i (1<i<n), satisfies ∑Xki (1<=k<=n)=∑Xij (1<=j<=n).这个说的是除了1,n外,所有的点的入度和出度都相等。

这样,突然就想到了图的特点,这样我们想象一下,超级原点1,超级汇点n,中间所有的都是入度等于出度,让我们找一个最小的花费满足上面的3点要求,而且最关键的是所有点的权值都是 >= 0的,这样我们就可以用最短路去跑了,直接跑1->n之间的最短路,可能有人想,跑最短路不是直接就默认中间的点的部分所有的入度和出度都是1了?没错,所有的都是1,因为想象一下,能用1就满足题意了,还有必要再多跑吗?这个地方不要想矩阵的问题,不然很容易蒙的,这样我们跑出最短路c,这个是一种情况,还有另一种情况就是可以直接从1跑一个最小环得到花费c1,然后从n跑一个环得到最小花费c2,两个环也满足上面的三个限制,这样我们只要输出min(c
,c1 + c2)就行了,对了还有一个差点忘记说了,至于找最小花费环,方法很多,可以直接搜索,说一个对于这个题目比较简单的方法(在网上看的!嘿嘿),我们可以在跑最短路的时候先别把起始点入队,把起始点连接的所有点入队,这样跑完

之后,到起始点的最短距离就是最小环了(具体看代码),以上就是我对网上题解的理解,目前只有这些,可能不对,很希望能和看到的人一起交流研究这个题目。


#include<stdio.h>
#include<string.h>
#include<queue> #define N_node 330
#define INF 1000000000

using namespace
std; int cost[N_node][N_node];
int
s_x[N_node] ,mark[N_node]; void spfa(int s ,int n)
{
for(int
i = 0 ;i <= n ;i ++)
s_x[i] = INF ,mark[i] = 0;
queue<int>q;
for(int
i = 1 ;i <= n ;i ++)
{
if(
s == i) continue;
s_x[i] = cost[s][i];
mark[i] = 1;
q.push(i);
}
while(!
q.empty())
{
int
xin ,tou;
tou = q.front();
q.pop();
mark[tou] = 0;
for(int
i = 1 ;i <= n ;i ++)
{

xin = i;
if(
s_x[xin] > s_x[tou] + cost[tou][xin])
{

s_x[xin] = s_x[tou] + cost[tou][xin];
if(!
mark[xin])
{

mark[xin] = 1;
q.push(xin);
}
}
}
}
} int main ()
{
int
i ,j ,n;
while(~
scanf("%d" ,&n))
{
for(
i = 1 ;i <= n ;i ++)
for(
j = 1 ;j <= n ;j ++)
scanf("%d" ,&cost[i][j]);
spfa(1 ,n);
int
Ans = s_x[n];
int
c1 = s_x[1];
spfa(n ,n);
int
c2 = s_x[n];
if(
Ans > c1 + c2) Ans = c1 + c2;
printf("%d\n" ,Ans);
}
return
0;
}

hdu4370 比较抽象的最短路的更多相关文章

  1. HDU-4370 '0 or 1' 最短路 要考虑连通性

    题目链接:https://cn.vjudge.net/problem/HDU-4370 题意 给一个矩阵C(nn),要我们找到一个矩阵X(nn),满足以下条件: X_{12}+X_{13}+...X_ ...

  2. HDU4370 0 or 1 最短路

    分析: 1001  (已更新) 显然,题目给的是一个0/1规划模型.解题的关键在于如何看出这个模型的本质.3个条件明显在刻画未知数之间的关系,从图论的角度思考问题,容易得到下面3个结论:1.X12+X ...

  3. poj3744 Scout YYF I

    题意:n个地雷(n<=10)在长度10^8的坐标轴上,yyf从横坐标为1的点开始,每一步有p的概率向右跳一格,(1-p)的概率向右跳两格(不会踩到中间一格),如果踩到地雷他就会死.问活下来的概率 ...

  4. hdu4370 0 or 1【最短路+建图】

    转载请注明出处,谢谢:http://www.cnblogs.com/KirisameMarisa/p/4297627.html   ---by 墨染之樱花 题目链接:http://acm.hdu.ed ...

  5. hdu4370 dijkstra矩阵转单向边最短路矩阵+自环闭环

    /* 矩阵太神奇了Orz,网上的题解大多是spfa,不过我发想dijkstra也能做 把n*n的矩阵看成是单向边距离矩阵就行 */ #include<iostream> #include& ...

  6. HDU4370:0 or 1(最短路)

    0 or 1 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4370 Description: Given a n*n matrix Cij (1< ...

  7. FJNU 1196 汪老司机(DP or 建图+最短路)

    1196: 汪老司机 Time Limit: 1000 MS         Memory Limit: 257792 KB 64-bit interger IO format: %lld       ...

  8. 【66测试20161115】【树】【DP_LIS】【SPFA】【同余最短路】【递推】【矩阵快速幂】

    还有3天,今天考试又崩了.状态还没有调整过来... 第一题:小L的二叉树 勤奋又善于思考的小L接触了信息学竞赛,开始的学习十分顺利.但是,小L对数据结构的掌握实在十分渣渣.所以,小L当时卡在了二叉树. ...

  9. UVA 11374 Airport Express(最短路)

    最短路. 把题目抽象一下:已知一张图,边上的权值表示长度.现在又有一些边,只能从其中选一条加入原图,使起点->终点的距离最小. 当加上一条边a->b,如果这条边更新了最短路,那么起点st- ...

随机推荐

  1. 关于《Android编程权威指南》的MockWalker在模拟器中无法运行的解决方法

    1.打开模拟器中的Dev Settings应用. 2.选中Allow mock locations选项. 之后应该就能正常运行了.

  2. vs2019远程调试

    VS2019远程调试 这几天遇到个很是纠结的问题,同样的源代码,放在测试服务器,完美运行.但是上线正式环境就是死活显示不出来.于是想到了微软的远程调试功能,这里用VS2019举例. 下载远程访问工具 ...

  3. TKE 容器网络中的 ARP Overflow 问题探究及其解决之道

    作者朱瑜坚,腾讯云后台开发工程师,熟悉 CNI 容器网络相关技术,负责腾讯云 TKE 的容器网络的构建和相关网络组件的开发维护工作,作为主力开发实现了 TKE 下一代容器网络方案. 1. 问题背景 1 ...

  4. 关于IO

    前言 IO在计算机中指Input/Output,也就是输入和输出.由于程序和运行时数据是在内存中驻留,由CPU这个超快的计算核心来执行,涉及到数据交换的地方,通常是磁盘.网络等,就需要IO接口.IO指 ...

  5. redis集群(redis_cluster)

    一.为什么要使用redis-cluster? 1.数据并发问题 2.数据量太大 新浪微博作为世界上最大的redis存储,就超过1TB的数据,去哪买这么大的内存条?各大公司有自己的解决方案,推出各自的集 ...

  6. [BJOI2020] 封印

    一.题目 点此看题 二.解法 今天不知道为什么手感这么好,写一发完全没调就过掉了. 我感觉这种多组询问的字符串题是很难的,经常没有什么思路.我先考虑了一下能不能像 区间本质不同的子串个数 这样直接离线 ...

  7. 时间&空间(complexity)

    时间&空间复杂度 时间复杂度: 通俗来说就是随着数据量的增加,程序运行的时间花费量是怎么变化的,时间复杂度常用大o表示.举个例子,猜数字,猜10个,100个.1000个,猜数的数据量是在增加的 ...

  8. socket 之send和recv原理剖析

    认识TCP socket的发送缓冲区和接收缓冲区 当创建一个TCP socket对象的时候会有一个发送缓冲区和一个接收缓冲区,相当与内存中的一片空间 send原理剖析 send是不是直接把数据发送给服 ...

  9. python3 int() 各数据类型转int

    print(int('0b1010',0))#二进制数print(int('0xa',0))#十六进制数print(int('0xa',16))print(int('a',16))print(int( ...

  10. 「HTML+CSS」--自定义加载动画【006】

    前言 Hello!小伙伴! 首先非常感谢您阅读海轰的文章,倘若文中有错误的地方,欢迎您指出- 哈哈 自我介绍一下 昵称:海轰 标签:程序猿一只|C++选手|学生 简介:因C语言结识编程,随后转入计算机 ...