B. Wycieczki

题目描述

给定一张n个点m条边的带权有向图,每条边的边权只可能是1,2,3中的一种。
将所有可能的路径按路径长度排序,请输出第k小的路径的长度,注意路径不一定是简单路径,即可以重复走同一个点。

输入格式

第一行包含三个整数n,m,k(1<=n<=40,1<=m<=1000,1<=k<=10^18)。
接下来m行,每行三个整数u,v,c(1<=u,v<=n,u不等于v,1<=c<=3),表示从u出发有一条到v的单向边,边长为c。
可能有重边。

输出格式

包含一行一个正整数,即第k短的路径的长度,如果不存在,输出-1。

样例

样例输入

6 6 11
1 2 1
2 3 2
3 4 2
4 5 1
5 3 1
4 6 3

样例输出

4

数据范围与提示

长度为1的路径有1->2,5->3,4->5。
长度为2的路径有2->3,3->4,4->5->3。
长度为3的路径有4->6,1->2->3,3->4->5,5->3->4。
长度为4的路径有5->3->4->5。

这道题时间跨度比较长了,主要是因为这道题贼难调,稍有不慎就会WA,而且这道题的测试点贼多,多到会出现2分情况,所以真的是我的签名说的,一杯茶一包纸,一份代码调成X

其实这道题还算好像,而且有思维量,主要就是要把边的矩阵拆点,然后建边,注意需点,也就是整个矩阵会扩大三倍;整个题其实就是二分(我打了一半,跑的实在是太慢了,所以换了一种方法)倍增,倍增就和求lca其实是一样的,就是换成了矩阵,不知其他神犇是怎么打的,反正我是使用结构体,但是要注意细节,整个卡了一晚上,就是因为矩阵传参没加取地址,加上就A了,有神犇知道为啥的就留言吧

#include<cstdio>
#include<cstring>
#include<cmath>
#include<iostream>
using namespace std;
#define LL long long
#define re register
#define F(i,a,b) for(LL i=a;i<=b;i++)
LL n,m,u,v,d,t;
long long s,k;
bool flag;
inline LL read()
{
re LL ss=;char bb=getchar();
while(bb<||bb>)bb=getchar();
while(bb>=&&bb<=)ss=(ss<<)+(ss<<)+(bb^),bb=getchar();
return ss;
}
struct Martix
{
LL x[][];
void init()
{
memset(x,,sizeof(x));
}
}mul[],tmp;
Martix bg,base,now;
void made(Martix &a,Martix &b,Martix &c)
{
flag=;
tmp.init();
F(i,,*n+)
F(l,,*n+)
{
if(!a.x[i][l])continue;
//debug(i);debug(l);
F(j,,*n+)
tmp.x[i][j]=tmp.x[i][j]+a.x[i][l]*b.x[l][j];
if(i==&&tmp.x[i][*n+]>=k)flag=;
}
c=tmp;
}
int main()
{
//freopen("cnm.txt","r",stdin);
n=read(),m=read(),k=read();
F(i,,n)
{
bg.x[][i]=;
base.x[i][i+n]=;
base.x[i+n][i+*n]=;
}
while(m--)
{
u=read(),v=read(),d=read();
base.x[u+(d-)*n][v]++;
base.x[u+(d-)*n][*n+]++;
}
base.x[*n+][*n+]=;
mul[]=base;
for(;t<=;t++)
{
if(t)
made(mul[t-],mul[t-],mul[t]);
made(bg,mul[t],now);
if(!flag||now.x[][*n+]>=k){break;}
}
t--;
if(t==&&now.x[][*n+]<k)
{
puts("-1");
return ;
}
for(LL i=t;i>=;i--)
{
made(bg,mul[i],now);
if(flag&&now.x[][*n+]<k)
{
s+=(1ll<<i);
bg=now;
}
}
printf("%lld\n",s+);
}

hhh

endl;

最新文章

  1. [CareerCup] 9.8 Represent N Cents 美分的组成
  2. html a标签包含a标签,浏览器的行为处理
  3. Linux_JDK安装
  4. Effective STL中文版 译序
  5. Scrum4.0
  6. xml数据解析调研
  7. php大力力 [027节] 被百度收录较好的几个视频网站示例
  8. BZOJ 2173 整数的lqp拆分
  9. Codeforces 430B Balls Game(Two Pointers)
  10. android键盘锁定问题
  11. Python import其他层级的模块
  12. 使用 Docker 部署 Grafana + Prometheus 监控 MySQL 数据库
  13. face recognition[Euclidean-distance-based loss][FaceNet]
  14. yii2 basic版基础部分
  15. Java GC机制
  16. laravel ORM 模型关联 with () 用法
  17. Element div is not closed
  18. App界面设计利器Sketch 精选案例合集
  19. cocos2d-x 3.0 将cpp-tests编译成Android版本号APK文件
  20. tomcat如何禁止显示目录和文件列表

热门文章

  1. python编程基础之二十五
  2. winsock完成端口套接字重用注意事项
  3. .Net Core3.0使用gRPC
  4. Java编程思想——第17章 容器深入研究 读书笔记(三)
  5. Web安全 --Wfuzz 使用大全
  6. 深入理解Transformer及其源码解读
  7. java集合之Stack栈基础
  8. Spring Boot 2.X(十):自定义注册 Servlet、Filter、Listener
  9. ThingJS和传统3D开发的区别
  10. idea的tomcat实现热部署遇到的问题