Description

为增强体质,约翰决定举办一场奶牛接力跑比赛。比赛现场有一些接力位置,这些位置间有T条路连接,第i条路的长度为Li。 有N头奶牛需要参加比赛,领头的奶牛从位置S出发,她会按照你的指示沿着一条路跑到下个位置,把接力棒交给等在那里的下一头奶牛,就休息去了。每头奶牛重复这个过程这条接力路线的终点必须在位置E上。

奶牛数量较多,允许一些奶牛等候在同一位置,一条路也可以供多头奶牛奔跑。 奶牛们对接力跑兴趣不大,拜托你敷衍地设计一条总长度最短的路线。所以请设计一条由N段路组成的,起点在S,终点在E上的最短路线吧。

Input Format

第一行:四个用空格分开的整数:表示N,T,S和E,2 ≤ N ≤ 106,2 ≤ T ≤ 100,1 ≤ S, E ≤ 1000

第二行到T + 1行: 第i + 1行首先有一个正整数Li,表示第i条路的长度, 1 ≤ Li ≤ 1000,其次是Ui和Vi,表示第i条路连接的两个位置,1 ≤ Ui, Vi ≤ 1000

Output Format

第一行:单个整数,表示起点为S,终点为E,且恰好经过N段路的最短路线长度

------------------------------------------------------

正解 = 最短路+倍增+(貌似有个很傻的离散- =)

注意道题目中的 N 比较大,T却很小- =,

由于 Ui 与 Vi 的范围比 T 还大,显然中间有许多无用的点

离散之,

注意道题目中的 N 比较大,T却很小- =,

这说明一个点会被经过多次(显然),

原本最短路只能得到任意两点 i,j 的距离dis[i][j],

在这个基础上加一维 dis[i][j][k] 表示 i 到 j 且经过2k条路径的最短路径,

转移于folyed有些类似 dis[i][j][k]=dis[i][p][k-1]+dis[p][j][k-1](p为图中的点)

将 N 转为2进制 设为 T2,设f[i][j]为 从起点S 到 i 这个点经过了 (T2从左往右数j个1达到的值)条路径

f[i][j]=f[k][j-1]+dis[i][k][p](k为图中点)(p为 2^p

f[终点][T2 中 1 的个数]即为所求答案- =

Ps.好吧,我承认我表达能力挺拙计的- =

代码如下:

  1. #include<cstring>
  2. #include<algorithm>
  3. #include<cstdio>
  4. #include<string>
  5. #include<iostream>
  6. #include<queue>
  7. #define INF 999999999
  8. #define min(x,y) if(x>y||x==-1) x=y
  9. int P,dis[][][],f[][],N,T,S,E;
  10. int O, ok[];
  11. void Do(){
  12. for(int p=;(<<p)<=N;p++)
  13. for(int i=;i<=O;i++)
  14. for(int j=;j<=O;j++)
  15. for(int k=;k<=O;k++)
  16. if(dis[i][j][p]>dis[i][k][p-]+dis[k][j][p-])
  17. dis[i][j][p]=dis[i][k][p-]+dis[k][j][p-];
  18. }
  19. void Dp(){
  20. for(int i=;i<=;i++)
  21. for(int k=;k<=;k++)
  22. f[i][k]=INF;
  23. f[ok[S]][]=;
  24. int k=,p=;
  25. while(N){
  26. if(N&){
  27. ++k;
  28. for(int i=;i<=O;i++)
  29. for(int j=;j<=O;j++)
  30. if(f[i][k]>f[j][k-]+dis[i][j][p])
  31. f[i][k]=f[j][k-]+dis[i][j][p];
  32. }
  33. N>>=;
  34. ++p;
  35. }
  36. printf("%d",f[ok[E]][k]);
  37. }
  38. int main(){
  39. scanf("%d%d%d%d",&N,&T,&S,&E);
  40. for(int i=;i<=;i++)
  41. for(int j=;j<=;j++)
  42. for(int k=;k<=;k++)
  43. dis[i][j][k]=INF;
  44. for(int i=;i<=T;i++){
  45. int u,v,t;
  46. scanf("%d%d%d",&t,&u,&v);
  47. if(!ok[u]) ok[u]=++O;
  48. if(!ok[v]) ok[v]=++O;
  49. dis[ok[u]][ok[v]][]=dis[ok[v]][ok[u]][]=t;
  50. }
  51. Do();
  52. Dp();
  53. }

usaco 奶牛接力的更多相关文章

  1. 【BZOJ】【1046】/【POJ】【3613】【USACO 2007 Nov】Cow Relays 奶牛接力跑

    倍增+Floyd 题解:http://www.cnblogs.com/lmnx/archive/2012/05/03/2481217.html 神题啊= =Floyd真是博大精深…… 题目大意为求S到 ...

  2. BZOJ_[usaco2007 Nov]relays 奶牛接力跑_离散化+倍增弗洛伊德

    BZOJ_[usaco2007 Nov]relays 奶牛接力跑_离散化+倍增弗洛伊德 Description FJ的N(2 <= N <= 1,000,000)头奶牛选择了接力跑作为她们 ...

  3. 【BZOJ1706】[usaco2007 Nov]relays 奶牛接力跑 矩阵乘法

    [BZOJ1706][usaco2007 Nov]relays 奶牛接力跑 Description FJ的N(2 <= N <= 1,000,000)头奶牛选择了接力跑作为她们的日常锻炼项 ...

  4. USACO 奶牛抗议 Generic Cow Protests

    USACO 奶牛抗议 Generic Cow Protests Description 约翰家的N头奶牛聚集在一起,排成一列,正在进行一项抗议活动.第i头奶牛的理智度 为Ai,Ai可能是负数.约翰希望 ...

  5. [USACO]奶牛会展(背包)

    [USACO]奶牛会展 题目背景 奶牛想证明它们是聪明而风趣的.为此,贝西筹备了一个奶牛博览会,她已经对N 头奶牛进行 了面试,确定了每头奶牛的智商和情商. 题目描述 贝西有权选择让哪些奶牛参加展览. ...

  6. 「题解」:[线性代数]:relays 奶牛接力跑

    问题: relays 奶牛接力跑 时间限制: 1 Sec  内存限制: 256 MB 题面 题目描述 FJ的N(2 <= N <= 1,000,000)头奶牛选择了接力跑作为她们的日常锻炼 ...

  7. BZOJ 1706: [usaco2007 Nov]relays 奶牛接力跑

    Description FJ的N(2 <= N <= 1,000,000)头奶牛选择了接力跑作为她们的日常锻炼项目.至于进行接力跑的地点 自然是在牧场中现有的T(2 <= T < ...

  8. bzoj 1706: [usaco2007 Nov]relays 奶牛接力跑——倍增floyd

    Description FJ的N(2 <= N <= 1,000,000)头奶牛选择了接力跑作为她们的日常锻炼项目.至于进行接力跑的地点 自然是在牧场中现有的T(2 <= T < ...

  9. 【bzoj1706】[usaco2007 Nov]relays 奶牛接力跑 离散化+倍增Floyd

    题目描述 FJ的N(2 <= N <= 1,000,000)头奶牛选择了接力跑作为她们的日常锻炼项目.至于进行接力跑的地点 自然是在牧场中现有的T(2 <= T <= 100) ...

随机推荐

  1. 深入了解relative

    1.relative是自身定位,距原本位置的偏移 2.无侵入布局: 挪动位置,原本位置还在占据,并不会影响其他元素的布局   应用: 实现鼠标拖拽,比自身api好用 3.top/bottom 和 le ...

  2. C#事件作用和用法

    例如有下面的需求需要实现:程序主画面中弹出一个子窗口.此时主画面仍然可以接收用户的操作(子窗口是非模态的).子窗口上进行某些操作,根据操作的结果要在主画面上显示不同的数据. 即如下图所示: 大多数我们 ...

  3. 『奇葩问题集锦』Malformed lock file found: /var/cache/dnf/metadata_lock.pid.

    Malformed lock file found: /var/cache/dnf/metadata_lock.pid.Ensure no other dnf process is running a ...

  4. php学习,一个简单的Calendar(2) 一个简单的活动页面

    有了前面的基础,后面就是将页面展示出来. 预览图如下:1号和31号分别有活动,会一并显示出来   这里需要搞定几个问题,一个就是数据库的连接,我们用\sys\class\class.db_connec ...

  5. [記錄用]python py2app 檔案批次重新命名

    demo.py 主要作用為 將同目錄下 *.mp4 檔案批次重新命名 例如: aaa001.mp4 ---重新命名為--> 001.mp4 aaa002.mp4 ---重新命名為--> 0 ...

  6. WPF窗体禁用最大化按钮

    禁用WPF窗体的最大化按钮可以使用Windows API改变按钮状态的方法实现.使用GetWindowLong可以得到当前按钮的状态.使用SetWindowLong可以设置按钮的状态.使用SetWin ...

  7. STM32库函数实现方法

    一.概述 1.调用STM32库函数配置与直接配置寄存器 ① 直接配置寄存器 使用过51单片机的朋友都知道为了将IO口配置成某种特殊功能或者配置中断控制,我们先将需要如下步骤: 根据需要配置功能计算值- ...

  8. armv7a-mediatek451_001_vfp-linux-gnueabi-gcc: directory: No such file or directory 编译error

    release/vm_linux/output/hisense_android/mt5399_cn_android_JB/rel/obj/oss/source/arm_mali_ko/mali400- ...

  9. bzoj 3823: 定情信物 线性筛逆元

    3823: 定情信物 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 108  Solved: 2[Submit][Status] Descriptio ...

  10. 【技术贴】webservice 调用 Transport error : 401 Error:Una

    解决 webservice 调用之后报错:调用异常:Transport error : 401 Error:Unauthorized 授权失败. 加入如下代码 //Sap需要ws-security的认 ...