#include using namespace std; #if __has_include() #include using namespace atcoder; #endif using ll = long long; using ld = long double; #define all(s) (s).begin(),(s).end() #define vcin(n) for(ll i=0;i>n[i] #define rep2(i, m, n) for (int i = (m); i < (n); ++i) #define rep(i, n) rep2(i, 0, n) #define drep2(i, m, n) for (int i = (m)-1; i >= (n); --i) #define drep(i, n) drep2(i, n, 0) #define rever(vec) reverse(vec.begin(), vec.end()) #define sor(vec) sort(vec.begin(), vec.end()) #define fi first #define se second #define P pair //const ll mod = 998244353; const ll mod = 1000000007; const ll inf = 2000000000000000000ll; static const long double pi = 3.141592653589793; void YesNo(bool a){if(a){cout<<"Yes"< void chmax(T& t,const U& u){if(t void chmin(T& t,const U& u){if(t>u) t=u;} ll modPow(ll a, ll n, ll mod) { ll ret = 1; ll p = a % mod; while (n) { if (n & 1) ret = ret * p % mod; p = p * p % mod; n >>= 1; } return ret; } struct graph{ struct edge{ ll to,cost; }; ll v; vector> g; vector d; vector negative; vector diameter; vector topological_sort; ll diametercost; bool bipartitecheck; vector bipartite; graph(ll n){ init(n); } void init(ll n){ v=n; g.resize(n); d.resize(n); negative.resize(n); diameter.resize(n); bipartite.resize(n); for(int i=0;i,greater

> que; que.push(P(0,s)); while(!que.empty()){ P p=que.top(); que.pop(); ll V=p.second; if(d[V]d[V]+e.cost){ d[e.to]=d[V]+e.cost; que.push(P(d[e.to],e.to)); } } } } void BellmanFord(ll s){ for(int i=0;id[V]+e.cost){ d[e.to]=d[V]+e.cost; if(i==v-1){ negative[e.to]=true; negative[V]=true; } } } } } } void dfs(ll s){ for(int i=0;id[s]+e.cost){ d[e.to]=d[s]+e.cost; dfs2(e.to,s); } } } void treediameter(){ dfs(0); ll p=0; ll q=0; for(int i=0;i>n>>m; graph g(n+2*m); for(int i=0;i>k>>c; g.addedge(n+2*i,n+2*i+1,1); g.addedge(n+2*i+1,n+2*i,1); // cout<>s; s--; if(s%2){ g.addedge(n+2*i+1,s,s+1+c); g.addedge(s,n+2*i+1,s+1+c); // cout<inf/2){ cout<<-1<