题目链接

描述

AC_Grazy一直对江湖羡慕不已,向往着大碗吃肉大碗喝酒的豪情,但是“人在江湖漂,怎能

不挨刀",”人在江湖身不由己",如果自己的武功太差,在江湖会死的很惨,但是AC_Grazy没有

武功秘籍练不了绝世武功.有道是“山重水复疑无路,柳暗花明又一村”,在AC_Grazy家里面

竟然藏着一本书,书名竟然叫做【超级外挂】,竟然能在各种武功之间进行转化,据说是他爷

爷的爷爷的...爷爷传下来的...

闲着无事便拿来看看,只看一眼便再也停不下了,只见上面写着“纵横武林打遍天下无敌手武功心法秘籍收录”.

翻开第一篇一看竟然是【降龙十八掌】...

心法只是一个修练武功的途径,重要的是真气的多少,于是他便想利用外挂让武功之间进行转

化,来让真气无限增加,但是这个心法只能按照顺序转化,我们分别用 1号和2号来代替两种功法 当然转化会有一定的转化率f

比如1 0.5 2 便是把 1的一半真气转化给2 ,为了简化问题,我们每次都从1号秘籍开始进行转化,如果其中一个秘籍转化断了,那么以后的功法就不能转换。

  • 输入
  输入:首先输入一个数 T(T<=20)表示T组数据然后输入两个数n(2<=n<=500)和
m(1=<m<=2000)分别表示有n种秘籍,随后的m行分别输入
秘籍u(n>=u>0) 转化率 f (0<f<=10)秘籍 v.(0<v<=n)
  • 输出

    输出:如果可以无限增加真气输出Yes否则输出No.
  • 样例输入

    2

    3 3

    1 2 2

    2 2 3

    3 2 1

    4 3

    1 2 2

    3 2 4

    4 2 3
  • 样例输出

    Yes

    No

分析:

所谓的能够无限增加真气,就是说路径中形成了环路,所以是否能够形成一个增加的环路成了这道题的一个判断标准。对于路径中的每一个点,都可能通过每一个到它的路径的权值来松弛,所以有多少条到它的路径就最多能够松弛几次,也就最多能够入队几次,如果入队的次数大于这个点的入度的话,也就意味着一定通过同一条路径松弛了最少两次,也就形成了所谓的环路。

代码:

#include<stdio.h>
#include<iostream>
#include<vector>
#include<string.h>
#include<queue>
#define INF 0x3f3f3f3f
using namespace std;
vector<int> v[505];///一个动态的数组
int bj[505];///标记那个点有没有访问过
int du[505];///每一个城市的入度
double dis[505];///距离
int n,m;
double Tu[505][505];///存储两点间的转化率
void init()///初始化
{
memset(v,0,sizeof(v));
memset(du,0,sizeof(du));
for(int i=1; i<=n; i++)
for(int j=1; j<=n; j++)
{
if(i==j)
Tu[i][j]=0;
else
Tu[i][j]=-INF;
}
} bool spfa()
{
for(int i=1; i<=n; i++)
{
dis[i]=-INF;///因为这里要求的是最大值,所以初始化为最小值
bj[i]=0;
}
dis[1]=1;///初始值
int flag=1;
bj[1]=1;///标记点访问过
du[1]--;
queue<int>q;
q.push(1);
while(!q.empty())
{
flag=q.front();
q.pop();
bj[flag]=0;///出队后要把标记释放掉,因为可能会多次用到这个点松弛
for(int i=0; i<v[flag].size(); i++)
{
int t=v[flag][i];
if(dis[t]<dis[flag]*Tu[flag][t])///当前的值比松弛后要小
{
dis[t]=dis[flag]*Tu[flag][t];
if(bj[t]==0)
{
q.push(t);
bj[t]=1;
du[t]--;
if(du[t]<0)///形成环的标记
return true;
}
}
}
}
return false;
} int main()
{
int T;
scanf("%d",&T);
int u,d;
double f;
while(T--)
{
scanf("%d%d",&n,&m);
init();
while(m--)
{
scanf("%d%lf%d",&u,&f,&d);
v[u].push_back(d);
du[d]++;
Tu[u][d]=f;
}
if(spfa())
printf("Yes\n");
else
printf("No\n");
}
return 0;
}

NYOJ 973 天下第一 (最短路)的更多相关文章

  1. nyoj 1238(BFSor最短路)

    最少换乘 时间限制:2000 ms  |  内存限制:65535 KB 难度:3   描述 欧洲某城是一个著名的旅游胜地,每年都有成千上万的人前来观光旅行.Dr. Kong决定利用暑假好好游览一番.. ...

  2. NYIST 973 天下第一

    天下第一时间限制:1000 ms | 内存限制:65535 KB难度:3 描述AC_Grazy一直对江湖羡慕不已,向往着大碗吃肉大碗喝酒的豪情,但是“人在江湖漂,怎能 不挨刀",”人在江湖身 ...

  3. nyoj 115dijkstar求最短路

    #include<stdio.h> #include<string.h> #define inf 0x3fffffff #define N 1100 int ma[N][N], ...

  4. NYOJ 115 城市平乱 (最短路)

    * 题目链接* 描述 南将军统领着N个部队,这N个部队分别驻扎在N个不同的城市. 他在用这N个部队维护着M个城市的治安,这M个城市分别编号从1到M. 现在,小工军师告诉南将军,第K号城市发生了暴乱,南 ...

  5. nyoj 115 城市平乱 dijkstra最短路

    题目链接: http://acm.nyist.net/JudgeOnline/problem.php?pid=115 dijkstra算法. #include "stdio.h" ...

  6. nyoj 203 三国志(最短路加01背包)

    三国志 时间限制:3000 ms  |  内存限制:65535 KB 难度:5   描述 <三国志>是一款很经典的经营策略类游戏.我们的小白同学是这款游戏的忠实玩家.现在他把游戏简化一下, ...

  7. Nyoj 天下第一(spfa)

    描述 AC_Grazy一直对江湖羡慕不已,向往着大碗吃肉大碗喝酒的豪情,但是“人在江湖漂,怎能 不挨刀",”人在江湖身不由己",如果自己的武功太差,在江湖会死的很惨,但是AC_Gr ...

  8. NYoj 155最短路

    //dij #include<stdio.h> #include<string.h> #include<queue> using namespace std; #d ...

  9. NYOJ 1007

    在博客NYOJ 998 中已经写过计算欧拉函数的三种方法,这里不再赘述. 本题也是对欧拉函数的应用的考查,不过考查了另外一个数论基本定理:如何用欧拉函数求小于n且与n互质所有的正整数的和. 记eule ...

随机推荐

  1. 【数据库】 SQLite 语法

    [数据库] SQLite 语法 一 . 创建数据库 1. 只需创建数据库,只需创建文件,操作时将连接字符串指向该文件即可 2. 连接字符串 : data source = FilePath; 不能加密 ...

  2. Oracle 学习笔记(四)

    ​oracle表查询 使用逻辑操作符号  查询工资高于 500 或者是岗位为 MANAGER 的雇员,同时还要满足他们的姓名首字母为大写 J SELECT * FROM emp WHERE (sal ...

  3. java 判断上午/下午

    //结果为“0”是上午 结果为“1”是下午 public class GregorianTest { public static void main(String args[]) { Gregoria ...

  4. Vue学习(四):条件渲染

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. [leetcode-648-Replace Words]

    In English, we have a concept called root, which can be followed by some other words to form another ...

  6. 【集训试题】SiriusRen的卡牌 set

    题意概述: 给出N张卡牌,每张有三个属性a,b,c,同时给出所有属性可能的最大值A,B,C.对于一张卡牌,当这张卡牌至少有两个属性大于另外一张卡牌的对应两个属性的时候,认为这张卡牌更加优秀.现在问有多 ...

  7. 甲级1002 A+B for Polynomials (25)

    题目描述: This time, you are supposed to find A+B where A and B are two polynomials. Input Each input fi ...

  8. 怎么获取textarea中选中文字

    textarea设置select="saveSelectionText()" //保存选中内容 saveSelectionText: function () { var focus ...

  9. WCF身份验证一:消息安全模式之<Certificate>身份验证

    消息安全模式的证书身份验证方式,基于WSHttpBinding绑定协议的实现过程.主要内容:基本概念,然后是制作证书.服务端配置.客户端配置.总结.这里应该和Transport传输安全模式之证书身份验 ...

  10. C# 获取方法所在的 命名空间 类名 方法名

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.D ...