Submission #1303906
Source Code Expand
#include "bits/stdc++.h"
using namespace std;
#define FOR(i,j,k) for(int (i)=(j);(i)<(int)(k);++(i))
#define rep(i,j) FOR(i,0,j)
#define each(x,y) for(auto &(x):(y))
#define mp make_pair
#define mt make_tuple
#define all(x) (x).begin(),(x).end()
#define debug(x) cout<<#x<<": "<<(x)<<endl
#define smax(x,y) (x)=max((x),(y))
#define smin(x,y) (x)=min((x),(y))
#define MEM(x,y) memset((x),(y),sizeof (x))
#define sz(x) (int)(x).size()
#define pb push_back
typedef long long ll;
typedef pair<int, int> pii;
typedef vector<int> vi;
typedef vector<ll> vll;
int main(){
ios::sync_with_stdio(false);
cin.tie(0);
ll N, L, T;
cin >> N >> L >> T;
vll X(N), W(N), p(N);
rep(i, N) {
cin >> X[i] >> W[i];
if (W[i] == 1) {
p[i] = X[i] + T;
} else {
p[i] = X[i] - T;
}
p[i] %= L;
if (p[i] < 0)p[i] += L;
}
ll s = p[0];
sort(all(p));
ll id = 0;
FOR(i, 1, N) {
if (W[0] != W[i]) {
ll d = W[0] == 1 ? X[i] - X[0] : X[0] + L - X[i];
if (T >= (d + 1) / 2) {
ll y = (2 * T - d) / L + 1;
if (W[0] == 1)id += y;
else id -= y;
}
}
}
id %= N;
if (id < 0)id += N;
ll pos = 0;
rep(i, N)if (s == p[i]) {
pos = i;
if (N > 1 && W[0] == 1 && p[i] == p[(i + 1) % N])pos = (i + 1) % N;
if (N > 1 && W[0] == 2 && p[i] == p[(i + N - 1) % N])pos = (i + N - 1) % N;
break;
}
vll ans(N);
rep(i, N)ans[(id + i) % N] = p[(pos + i) % N];
rep(i, N)cout << ans[i] << endl;
}
Submission Info
Submission Time |
|
Task |
C - Ants on a Circle |
User |
paruki |
Language |
C++14 (GCC 5.4.1) |
Score |
700 |
Code Size |
1681 Byte |
Status |
AC |
Exec Time |
179 ms |
Memory |
4352 KB |
Judge Result
Set Name |
Sample |
All |
Score / Max Score |
0 / 0 |
700 / 700 |
Status |
|
|
Set Name |
Test Cases |
Sample |
sample_01.txt, sample_02.txt |
All |
sample_01.txt, sample_02.txt, sample_01.txt, sample_02.txt, subtask_1_01.txt, subtask_1_02.txt, subtask_1_03.txt, subtask_1_04.txt, subtask_1_05.txt, subtask_1_06.txt, subtask_1_07.txt, subtask_1_08.txt, subtask_1_09.txt, subtask_1_10.txt, subtask_1_11.txt, subtask_1_12.txt, subtask_1_13.txt, subtask_1_14.txt, subtask_1_15.txt, subtask_1_16.txt |
Case Name |
Status |
Exec Time |
Memory |
sample_01.txt |
AC |
1 ms |
256 KB |
sample_02.txt |
AC |
1 ms |
256 KB |
subtask_1_01.txt |
AC |
108 ms |
2688 KB |
subtask_1_02.txt |
AC |
86 ms |
2176 KB |
subtask_1_03.txt |
AC |
175 ms |
4352 KB |
subtask_1_04.txt |
AC |
179 ms |
4352 KB |
subtask_1_05.txt |
AC |
29 ms |
896 KB |
subtask_1_06.txt |
AC |
42 ms |
1152 KB |
subtask_1_07.txt |
AC |
174 ms |
3968 KB |
subtask_1_08.txt |
AC |
173 ms |
3968 KB |
subtask_1_09.txt |
AC |
116 ms |
2688 KB |
subtask_1_10.txt |
AC |
100 ms |
2304 KB |
subtask_1_11.txt |
AC |
25 ms |
768 KB |
subtask_1_12.txt |
AC |
157 ms |
3840 KB |
subtask_1_13.txt |
AC |
114 ms |
2944 KB |
subtask_1_14.txt |
AC |
105 ms |
2688 KB |
subtask_1_15.txt |
AC |
1 ms |
256 KB |
subtask_1_16.txt |
AC |
1 ms |
256 KB |