이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "Azer.h"
#include <bits/stdc++.h>
#define Loop(x,l,r) for (ll x = (l); x < (ll)(r); ++x)
#define LoopR(x,l,r) for (ll x = (r)-1; x >= (ll)(l); --x)
typedef long long ll;
typedef std::pair<int, int> pii;
typedef std::pair<ll , ll > pll;
using namespace std;
namespace {
const int N = 2048;
const int inf = 1e9;
vector<pii> A[N];
int dis[N];
set<pii> s;
int rem;
int n;
int want;
void (*want_func)();
queue<bool> q;
int lst_d;
int recv_up_d;
} // namespace
namespace {
void send(int x, int b)
{
cerr << "A send " << x << '\n';
while (b--) {
SendA(x & 1);
x /= 2;
}
}
int recv(int b)
{
int ans = 0;
Loop (i,0,b) {
ans ^= (int)q.front() << i;
q.pop();
}
cerr << "A recv " << ans << '\n';
return ans;
}
void up(int v, int d)
{
if (d >= dis[v])
return;
s.erase({dis[v], v});
dis[v] = d;
s.insert({dis[v], v});
}
void recv_up();
void cmp();
void dij();
void recv_up()
{
int v = recv(11);
up(v, recv_up_d);
dij();
}
void cmp()
{
int self = s.begin()->first;
int other = recv(9) + lst_d;
if (self > other) {
want = 11;
want_func = recv_up;
recv_up_d = other;
} else {
send(s.begin()->second, 11);
dij();
}
}
void dij()
{
auto [d, v] = *s.begin();
s.erase(s.begin());
for (auto [u, w] : A[v])
up(u, d+w);
lst_d = dis[v];
--rem;
if (!rem)
return;
int u = s.begin()->second;
send(dis[u] - lst_d, 9);
want = 9;
want_func = cmp;
}
}
void InitA(int _n, int m, std::vector<int> V, std::vector<int> U,
std::vector<int> W)
{
n = _n;
rem = n;
Loop (i,0,m) {
int v = V[i], u = U[i], w = W[i];
A[v].push_back({u, w});
A[u].push_back({v, w});
}
fill(dis, dis+n, inf);
up(0, 0);
dij();
}
void ReceiveA(bool x)
{
q.push(x);
--want;
if (!want) {
want_func();
}
}
std::vector<int> Answer()
{
vector<int> ans(n);
Loop (i,0,n)
ans[i] = dis[i];
return ans;
}
#include "Baijan.h"
#include <bits/stdc++.h>
#define Loop(x,l,r) for (ll x = (l); x < (ll)(r); ++x)
#define LoopR(x,l,r) for (ll x = (r)-1; x >= (ll)(l); --x)
typedef long long ll;
typedef std::pair<int, int> pii;
typedef std::pair<ll , ll > pll;
using namespace std;
namespace {
const int N = 2048;
const int inf = 1e9;
vector<pii> A[N];
int dis[N];
set<pii> s;
int rem;
int n;
int want;
void (*want_func)();
queue<bool> q;
int lst_d;
int recv_up_d;
} // namespace
namespace {
void send(int x, int b)
{
cerr << "B send " << x << '\n';
while (b--) {
SendB(x & 1);
x /= 2;
}
}
int recv(int b)
{
int ans = 0;
Loop (i,0,b) {
ans ^= (int)q.front() << i;
q.pop();
}
cerr << "B recv " << ans << '\n';
return ans;
}
void up(int v, int d)
{
if (d >= dis[v])
return;
s.erase({dis[v], v});
dis[v] = d;
s.insert({dis[v], v});
}
void recv_up();
void cmp();
void dij();
void recv_up()
{
int v = recv(11);
up(v, recv_up_d);
dij();
}
void cmp()
{
int self = s.begin()->first;
int other = recv(9) + lst_d;
if (self >= other) {
want = 11;
want_func = recv_up;
recv_up_d = other;
} else {
send(s.begin()->second, 11);
dij();
}
}
void dij()
{
auto [d, v] = *s.begin();
s.erase(s.begin());
for (auto [u, w] : A[v])
up(u, d+w);
lst_d = dis[v];
--rem;
if (!rem)
return;
int u = s.begin()->second;
send(dis[u] - lst_d, 9);
want = 9;
want_func = cmp;
}
}
void InitB(int _n, int m, std::vector<int> V, std::vector<int> U,
std::vector<int> W)
{
n = _n;
rem = n;
Loop (i,0,m) {
int v = V[i], u = U[i], w = W[i];
A[v].push_back({u, w});
A[u].push_back({v, w});
}
fill(dis, dis+n, inf);
up(0, 0);
dij();
}
void ReceiveB(bool x)
{
q.push(x);
--want;
if (!want) {
want_func();
}
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |