社区讨论
D不是同余最短路吗??
学术版参与者 4已保存回复 4
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 4 条
- 当前快照
- 1 份
- 快照标识符
- @mdb6pfxg
- 此快照首次捕获于
- 2025/07/20 12:36 8 个月前
- 此快照最后确认于
- 2025/11/04 04:04 4 个月前
1眼同余最短路,难道不是吗???
想了下感觉好像Dijikstra的vis性质不一定对但是也不知道错哪了能不能给个hack或者直接说吗解法错在哪,玄关。
WA2 卡我1h。
CPP#include <iostream>
#include <vector>
#include <algorithm>
#include <array>
#include <string>
#include <map>
#include <string>
#include <set>
#include <queue>
#include <cmath>
#include <tuple>
#include <stack>
#include <numeric>
#include <climits>
#include <deque>
#include <chrono>
#include <unordered_map>
#include <cstring>
using namespace std;
void __print(int x) {cerr << x;}
void __print(long x) {cerr << x;}
void __print(long long x) {cerr << x;}
void __print(unsigned x) {cerr << x;}
void __print(unsigned long x) {cerr << x;}
void __print(unsigned long long x) {cerr << x;}
void __print(float x) {cerr << x;}
void __print(double x) {cerr << x;}
void __print(long double x) {cerr << x;}
void __print(char x) {cerr << '\'' << x << '\'';}
void __print(const char *x) {cerr << '\"' << x << '\"';}
void __print(const string &x) {cerr << '\"' << x << '\"';}
void __print(bool x) {cerr << (x ? "true" : "false");}
template<typename T, typename V>
void __print(const pair<T, V> &x) {cerr << '{'; __print(x.first); cerr << ','; __print(x.second); cerr << '}';}
template<typename T>
void __print(const T &x) {int f = 0; cerr << '{'; for (auto &i: x) cerr << (f++ ? "," : ""), __print(i); cerr << "}";}
void _print() {cerr << "]\n";}
template <typename T, typename... V>
void _print(T t, V... v) {__print(t); if (sizeof...(v)) cerr << ", "; _print(v...);}
#ifndef ONLINE_JUDGE
#define debug(x...) cerr << "[" << #x << "] = ["; _print(x)
#define systemwait system("read -p \"Press Enter to continue...\"");
#else
#define debug(x...)
#define systemwait
#endif
#define int long long
#define endl '\n'
#define all(x) (x).begin(),(x).end()
#define sqsq(x) (x)*(x)
#define pii pair<int,int>
#define vi vector<int>
#define vii vector<pii>
const int INF=1e9+7;
const int MOD=1e9+7;
//const int MOD=998244353;
const int maxn=5005;
vi mp[maxn],vis[maxn];
vii dist[maxn];
pii ans;
int deg[maxn],N,M;
pii min(pii first,pii second) {
if(first.first<second.first || (first.first==second.first && first.second<second.second)) {
return first;
}
return second;
}
void Dijkstra(int src,int rmn) {
priority_queue<pii,vii,greater<pii>> pq;
dist[src][rmn]={0,0};
pq.push({0,src});
while(!pq.empty()) {
auto [l,u]=pq.top();
pq.pop();
if(vis[u][l%deg[u]]) {
continue;
}
vis[u][l%deg[u]]++;
int pos=0;
for(int v:mp[u]) {
int t=(deg[u]+pos-(l%deg[u]))%deg[u];
if(dist[v][(l+t+1)%deg[v]].first>(dist[u][l%deg[u]].first+t+1)
|| (dist[v][(l+t+1)%deg[v]].first==(dist[u][l%deg[u]].first+t+1) && dist[v][(l+t+1)%deg[v]].second>dist[u][l%deg[u]].second)) {
dist[v][(l+t+1)%deg[v]].first=(dist[u][l%deg[u]].first+t+1);
dist[v][(l+t+1)%deg[v]].second=(dist[u][l%deg[u]].second+t);
pq.push({dist[v][(l+t+1)%deg[v]].first,v});
}
pos++;
}
}
}
void solve() {
//--------Initiallize Boundless--------
memset(deg,0,sizeof(deg));
ans={0x3f3f3f3f3f3f3f3f,0x3f3f3f3f3f3f3f3f};
//--------Input--------
cin>>N>>M;
for(int i=1;i<=N;i++) {
mp[i].clear();
}
for(int i=1;i<=M;i++) {
int uu,vv;
cin>>uu>>vv;
deg[uu]++;
deg[vv]++;
mp[uu].push_back(vv);
mp[vv].push_back(uu);
}
for(int i=1;i<=N;i++) {
vis[i].assign(deg[i],0);
dist[i].assign(deg[i],{0x3f3f3f3f3f3f3f3f,0x3f3f3f3f3f3f3f3f});
}
// for(int i=1;i<=N;i++) {
// for(int j=0;j<N;j++) {
// vis[i][j]=0;
// dist[i][j]={0x3f3f3f3f,0x3f3f3f3f};
// }
// }
//--------No fluff real stuff--------
Dijkstra(1,0);
for(int i=0;i<deg[N];i++) {
ans=min(ans,dist[N][i]);
}
cout<<ans.first<<" "<<ans.second<<endl;
return;
}
int32_t main() {
ios::sync_with_stdio(false);
cin.tie(0);
int TT=1;
cin>>TT;
for(int i=1;i<=TT;++i) {
solve();
}
return 0;
}
回复
共 4 条回复,欢迎继续交流。
正在加载回复...