[USACO07NOV]牛继电器Cow Relays

题目描述

给出一张无向连通图,求S到E经过k条边的最短路。

输入输出样例

输入样例#1:
2 6 6 4
11 4 6
4 4 8
8 4 9
6 6 8
2 6 9
3 8 9
输出样例#1:
10
题解:
法1:dp+floyd+倍增
f[i][j][p]为从i到j经过2^p条边
显然f[i][j][p]=min(f[i][k][p-1]+f[k][j][p-1])
如果n不是2的幂也没事,将n进行二进制分解,再用dp转移
ans[x][i]=min(ans[!x][j]+f[i][j][p]) n的二进制第p位为1
 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 #include<algorithm>
 5 #include<cmath>
 6 using namespace std;
 7 int n,t,s,e,f[201][201][25],ans[2][201],num[1005],pos,logn;
 8 int main()
 9 {int i,d,u,v,p,j,k;
10     cin>>n>>t>>s>>e;
11     memset(f,127/3,sizeof(f));
12     memset(ans,127/2,sizeof(ans));
13     for (i=1;i<=t;i++)
14     {
15         scanf("%d%d%d",&d,&u,&v);
16         if (!num[u]) num[u]=++pos;
17         if (!num[v]) num[v]=++pos;
18         f[num[u]][num[v]][0]=f[num[v]][num[u]][0]=d;
19     }
20      logn=log2(n);
21       for (p=1;p<=logn;p++)
22       {
23             for (k=1;k<=pos;k++)
24             {
25                 for (i=1;i<=pos;i++)
26                 {
27                     for (j=1;j<=pos;j++)
28                     {
29                         f[i][j][p]=min(f[i][j][p],f[i][k][p-1]+f[k][j][p-1]);
30                     }
31                 }
32             }
33       }
34       t=0;p=0;
35       ans[0][num[s]]=0;
36         while (n)
37         {
38             if (n&1)
39             {
40                 t=!t;
41                  for (i=1;i<=pos;i++)
42                  {ans[t][i]=2e9;
43                     for (j=1;j<=pos;j++)
44                     {
45                         ans[t][i]=min(ans[t][i],ans[!t][j]+f[i][j][p]);
46                     }    
47                  }
48             }
49             p++;
50             n/=2;
51         }
52     cout<<ans[t][num[e]];
53 }
 

 

 
 

法二:矩阵乘法

可知用邻接矩阵表示时,floyd的过程可以视为矩阵运算,且满足交换律

意思就是先求出走1条边的矩阵,再求出找4条边矩阵

等价于先求出走2条边的矩阵,在求出找3条边矩阵

重载矩阵乘法为floyd的过程,做快速幂就行

 

 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 #include<algorithm>
 5 #include<cmath>
 6 using namespace std;
 7 int n,t,s,e,f[201][201],num[1005],pos;
 8 struct mat
 9 {
10     int s[101][101];
11     mat()
12     {int i,j;
13         for (i=1;i<=pos;i++)
14          for (j=1;j<=pos;j++)
15          s[i][j]=1e9;
16     }
17      mat operator*(const mat &x)
18      {int i,j,k;
19         mat ans;
20         for (k=1;k<=pos;k++)
21         {
22             for (i=1;i<=pos;i++)
23              {
24                 for (j=1;j<=pos;j++)
25                 {
26                     ans.s[i][j]=min(ans.s[i][j],s[i][k]+x.s[k][j]);
27                 }
28              }
29         }
30         return ans;
31      }
32 }S,T;
33 int main()
34 {int i,j,d,u,v;
35     cin>>n>>t>>s>>e;
36     for (i=1;i<=t;i++)
37     {
38         scanf("%d%d%d",&d,&u,&v);
39         if (!num[u]) num[u]=++pos;
40         if (!num[v]) num[v]=++pos;
41         f[num[u]][num[v]]=f[num[v]][num[u]]=d;
42     }
43     mat S,T;
44     for (i=1;i<=pos;i++)
45     for (j=1;j<=pos;j++)
46     if (f[i][j])
47      S.s[i][j]=T.s[i][j]=f[i][j];
48       n--;
49       while (n)
50       {
51             if (n&1)
52             {
53                 S=S*T;
54             }
55             T=T*T;
56             n>>=1;
57       }
58     cout<<S.s[num[s]][num[e]];
59 }

 

 

 

转载于:https://www.cnblogs.com/Y-E-T-I/p/7366430.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/268650.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

oracle 时间小于,jquery easyui 对于开始时间小于结束时间的判断示例

对于开始时间小于结束时间的判断可以参考,jquery easyui里的ValidateBox进行判断好吧!直接上代码查看内容&#xff1a;按时间&#xff1a;至var varify;//用于查询验证,验证开始时间是否小于结束时间function query2(pid){if(varify){startTime2 $(#start2).datetimebox(getVa…

mysql安装与基本使用

Mysql数据库的基本使用服务端1.安装&#xff1a;sudo apt-get install mysql-service2.启动&#xff1a;sudo service mysql start3.查看进程中是否存在mysql服务&#xff1a;ps ajx|grep mysql (/usr/sbin/mysqld)4.停止服务&#xff1a;sudo service mysql stop5.重启服务&am…

批处理获取exe返回结果

echo off e:\a.exe a b c IF ERRORLEVEL 1 goto error IF ERRORLEVEL 0 goto success :error echo error goto end :success echo success goto end :end :: IF %ERRORLEVEL% LEQ 1 goto ::EQU - 等于 ::NEQ - 不等于 ::LSS - 小于 ::LEQ - 小于或等于 ::GTR - 大于 ::GEQ - 大…

centos7安装nginx和php,centos7安装nginx1.10和php7

安装nginx。1.首先在根目录下创建一个software文件夹用来存储下载的压缩包。2.然后cd跳转的software文件夹下&#xff0c;进行压缩包的下载wget -c https://nginx.org/download/nginx-1.10.1.tar.gz3.解压&#xff0c;然后跳转到解压的目录下tar -zxvf nginx-1.10.1.tar.gzcd n…

Java-日期 正则表达式

Java 日期和时间 Data类提供两个构造函数来实例化Data对象 Data()//参数是从1970 1 1 起的毫秒数Data(long millisec)获取当前日期时间 import java.util.Data;public class DataDemo {public static void main(String args[]) {// 初始化Data对象Data data new Data();//…

CCNA考试必看

成功者的经验&#xff0c;对我们来说&#xff0c;无疑是非常重要的&#xff0c;因为他们不但知道了成功的路&#xff0c;而且&#xff0c;经历过失败&#xff0c;知道哪些路是走不通的&#xff0c;这些经验对于后来者有很好的参考价值。已经通过CCNA的朋友&#xff0c;都非常愿…

oracle恢复指定数据文件,Oracle特殊恢复-BBED修改某个数据文件头

Oracle数据文件头中的scn要与控制文件中的scn一致&#xff0c;数据库才可以open&#xff0c;在open过程中我们可以通过bbed来修改某个数据文件头的scn&#xff0c;来欺骗oracle&#xff0c;来open库。1、环境如下使用Oracle 11gR2进行测试&#xff0c;具体版本为11.2.0.4SYSlin…

shell管道重定向程序的实现

管道常用于不同命令的组合使用&#xff0c;比如ps -aux|grep ..用于查找指定条件的进程&#xff0c;ls|less用于实现文件列表的分页显示等。总之是将前一个命令的输出作为后一个命令的输入&#xff0c;完成一个命令无法完成的功能。分别使用pipe()和popen()两种方式实现ls|less…

移动端网站,键盘弹出对页面的影响

在移动端网站中&#xff0c;ios与安卓键盘弹出时对页面有不同的处理方式。 ios&#xff0c;键盘弹出但整体页面高度不变。 安卓&#xff0c;页面高度屏幕高度-键盘高度 这样对页面样式就会造成不同的影响。 当有表单弹窗&#xff0c;且弹窗高度在页面高度的50%左右时影响尤为严…

Hyper-V和多处理器虚机

架构概述Hyper-V采用基于Hyperisor的架构&#xff0c;并且充分利用Windows驱动模型&#xff0c;以便提供广泛的硬件支持。Hypervisor可以把单个服务器划分为多个CPU和内存的容器。由于采用微内核架构&#xff0c;Hyper-V可以提供高效的分区间通信机制&#xff0c;并在此基础上搭…

oracle 11g 修改 sga,oracle 11g 调整SGA

1. 查看oracle 使用的参数文件SQL> show parameter spfileNAME TYPE VALUE------------------------------------ ----------- ------------------------------spfile string /u01/app/oracle/p…

Vue.js(2.x)之Class 与 Style 绑定

1、前面看数据绑定时还很困惑v-bind处理class时可以使用json格式的值&#xff0c;为什么换成id、href等其他属性就不行。看了下文档解释后明白了些&#xff1a; 2.对象语法主要有以下三种形式&#xff1a; 1&#xff09;直接在v-bind指令后使用键值对形式&#xff1a;键是否显示…

软件外包项目中的进度管理

案例 A公司是一家美资软件公司在华办事机构&#xff0c;其主要的目标是开拓中国市场、服务中国客户&#xff0c;做一些本地化和客户化的工作。它的主要软件产品是由总部在硅谷的软件开发基地完成&#xff0c;然后由世界各地的分公司或办事机构进行客户化定制、二次开发和系统维…

请求转发和请求重定向的区别?

请求重定向Redirect&#xff1a; 1. 产生了两次请求&#xff0c;俩次相应 , 所以浏览器地址会发生改变 !2. 可以重新定向到非本项目的服务器地址! 请求转发forword&#xff1a; 1. 产生了一次请求&#xff0c;一次相应 , 所以浏览器地址不会发生变化 !2. 只能转发到本项目的服务…