题目大意:给定 N 个点,M 条边的有向图,边有边权,求从 1 号顶点到 N 号顶点的最短乘积路径.(经过的路径乘积最小)结果对9987取模. 乘积会爆 long long ,同时由于 dij 算法的性质,又不能在 bfs 的过程中对答案取模. 同时,根据对数的性质有 \(log(x)+log(y)=log(xy)\),因此,可以采用将边权取对数存入邻接表中,dij 比较的时候用这个取对数之后的边权比较,并记录路径,最后按照路径还原统一处理答案. 代码如下 #include <bits/stdc…
嗯... 题目链接:https://www.luogu.org/problem/P2239 这道题首先不能暴力建图,没有简单方法,只有进行进行找规律. AC代码: #include<cstdio> #include<iostream> using namespace std; inline int work(int n, int x, int y){ ) return y; ; * n - - y; ) * n - - x; , x - , y - ) + * (n - ); }…