QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#35069#4251. Gamewe_wendys2 8ms17908kbC++142.4kb2022-06-13 06:15:162022-06-13 06:15:18

Judging History

你现在查看的是最新测评结果

  • [2023-08-10 23:21:45]
  • System Update: QOJ starts to keep a history of the judgings of all the submissions.
  • [2022-06-13 06:15:18]
  • 评测
  • 测评结果:2
  • 用时:8ms
  • 内存:17908kb
  • [2022-06-13 06:15:16]
  • 提交

answer

//https://qoj.ac/contest/948/problem/4251
//#pragma GCC optimize("O3")
//#pragma GCC optimization ("unroll-loops")
//#pragma GCC target("avx,avx2,fma")
//#pragma GCC target("sse,sse2,sse3,ssse3,sse4,popcnt,abm,mmx,tune=native")
#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
#include "game.h"
using namespace __gnu_pbds;
using namespace std;

#define pb push_back
#define ff first
#define ss second

typedef long long ll;
typedef long double ld;
typedef pair<int, int> pii;
typedef pair<ll, ll> pll;
typedef pair<ld, ld> pld;

const int INF = 1e9;
const ll LLINF = 1e18;
const int MOD = 1e9 + 7;

template<class K> using sset =  tree<K, null_type, less<K>, rb_tree_tag, tree_order_statistics_node_update>;

inline ll ceil0(ll a, ll b) {
    return a / b + ((a ^ b) > 0 && a % b);
}

const int MX = 300;
int n, k;
int l[300005][2], r[300005][2];
vector<int> g1[300005];
vector<int> g2[300005];

void dfs1(int x){
	if(x < k) return;
	for(int i : g1[x]){
		if(r[x][0] > r[i][0]){
			r[i][0] = r[x][0];
			dfs1(i);
		}
	}
}

void dfs2(int x){
	if(x < k) return;
	for(int i : g2[x]){
		if(l[x][0] < l[i][0]){
			l[i][0] = l[x][0];
			dfs2(i);
		}
	}
}

void init(int n_, int k_){
	n = n_, k = k_;
	for(int i = 0; i < k; i++) l[i][0] = r[i][0] = i/MX, l[i][1] = r[i][1] = i;
	for(int i = k; i < n; i++) l[i][0] = l[i][1] = INF, r[i][0] = r[i][1] = -INF;
}

void dfs3(int x){
	for(int i : g1[x]){
		if(r[x][0] == r[i][0] && r[x][1] > r[i][1]){
			r[i][1] = r[x][1];
			dfs3(i);
		}
	}
}

void dfs4(int x){
	for(int i : g2[x]){
		if(l[x][0] == l[i][0] && l[x][1] < l[i][1]){
			l[i][1] = l[x][1];
			dfs4(i);
		}
	}
}

int add_teleporter(int u, int v){
	if(u < k && v < k && u >= v) return 1;
	if(u == v) return 0;
	g1[u].pb(v);
	g2[v].pb(u);
	bool prv = (l[u][0] > r[u][0] || l[v][0] > r[v][0]);
	r[v][0] = max(r[v][0], r[u][0]);
	l[u][0] = min(l[u][0], l[v][0]);
	r[v][1] = max(r[v][1], r[u][1]);
	l[u][1] = min(l[u][1], l[v][1]);
	dfs1(v);
	dfs2(u);
	if(v > k && r[v][0] > l[v][0]) return 1;
	if(v > k && r[v][1] >= l[v][1]) return 1;
	if(u > k && r[u][0] > l[u][0]) return 1;
	if(u > k && r[u][1] >= l[u][1]) return 1;
	for(int i = l[u][0]*MX; i < min(k, (l[u][0] + 1)*MX); i++){
		dfs3(i);
		dfs4(i);
	}
	if(v > k && r[v][1] >= l[v][1]) return 1;
	if(u > k && r[u][1] >= l[u][1]) return 1;
	return 0;
}

详细

Subtask #1:

score: 2
Accepted

Test #1:

score: 2
Accepted
time: 2ms
memory: 17808kb

input:

1 1
1
893123 893123
-1

output:

0

result:

ok interaction finished.

Test #2:

score: 0
Accepted
time: 2ms
memory: 17784kb

input:

9 9
29
893122 893124
893121 893127
893120 893124
893123 893121
893122 893131
893125 893131
893121 893126
893123 893126
893126 893131
893123 893131
893123 893125
893123 893124
893127 893125
893120 893126
893123 893120
893121 893131
893123 893127
893122 893126
893122 893127
893127 893131
893122 893125...

output:

28

result:

ok interaction finished.

Test #3:

score: 0
Accepted
time: 4ms
memory: 17908kb

input:

100 100
80
893180 893071
893134 893063
893150 893091
893127 893178
893142 893177
893153 893156
893127 893137
893174 893065
893127 893070
893126 893061
893171 893089
893173 893072
893153 893058
893156 893074
893151 893068
893136 893060
893120 893083
893073 893091
893148 893163
893073 893088
893156 89...

output:

80
80
80
59

result:

ok interaction finished.

Test #4:

score: 0
Accepted
time: 8ms
memory: 17740kb

input:

45 45
80
893143 893167
893122 893132
893123 893140
893120 893139
893158 893167
893154 893163
893133 893137
893133 893142
893135 893137
893121 893135
893137 893149
893141 893152
893122 893167
893128 893145
893140 893167
893122 893127
893134 893142
893122 893129
893141 893156
893146 893149
893123 8931...

output:

80
49

result:

ok interaction finished.

Test #5:

score: 0
Accepted
time: 2ms
memory: 17792kb

input:

100 100
80
893169 893058
893132 893065
893143 893068
893153 893167
893152 893182
893138 893162
893129 893163
893146 893164
893134 893180
893142 893167
893144 893059
893132 893064
893135 893091
893164 893068
893123 893179
893126 893060
893136 893140
893179 893081
893139 893181
893120 893057
893172 89...

output:

80
80
80
42

result:

ok interaction finished.

Test #6:

score: 0
Accepted
time: 4ms
memory: 17792kb

input:

100 100
80
893135 893081
893170 893076
893148 893075
893134 893159
893159 893073
893170 893088
893131 893138
893121 893166
893171 893168
893127 893137
893147 893145
893062 893076
893160 893059
893063 893088
893137 893073
893123 893182
893152 893170
893141 893172
893137 893087
893167 893085
893147 89...

output:

80
80
80
37

result:

ok interaction finished.

Test #7:

score: 0
Accepted
time: 2ms
memory: 17828kb

input:

100 100
80
893062 893075
893139 893156
893137 893083
893071 893075
893072 893080
893141 893060
893126 893179
893064 893081
893167 893077
893139 893165
893056 893085
893169 893182
893062 893087
893141 893078
893062 893078
893129 893176
893065 893077
893141 893181
893152 893158
893151 893078
893157 89...

output:

80
80
80
59

result:

ok interaction finished.

Subtask #2:

score: 0
Runtime Error

Dependency #1:

100%
Accepted

Test #8:

score: 0
Runtime Error

input:

100 10
80
893135 893150
893174 893168
893159 893149
893162 893082
893158 893129
893072 893150
893088 893079
893155 893154
893086 893126
893078 893153
893177 893138
893057 893066
893151 893089
893076 893162
893165 893164
893085 893170
893084 893128
893074 893083
893138 893148
893147 893167
893071 893...

output:


result:


Subtask #3:

score: 0
Skipped

Dependency #2:

0%

Subtask #4:

score: 0
Skipped

Dependency #3:

0%

Subtask #5:

score: 0
Skipped

Dependency #1:

100%
Accepted

Dependency #2:

0%