Submission #209348

# Submission time Handle Problem Language Result Execution time Memory
209348 2020-03-13T22:55:50 Z mode149256 Paint By Numbers (IOI16_paint) C++14
100 / 100
1358 ms 99372 KB
/*input

*/
#include <bits/stdc++.h>
#include "paint.h"

using namespace std;

typedef long long ll;
typedef long double ld;
typedef complex<ld> cd;

typedef pair<int, int> pi;
typedef pair<ll, ll> pl;
typedef pair<ld, ld> pd;

typedef vector<int> vi;
typedef vector<vi> vii;
typedef vector<ld> vd;
typedef vector<ll> vl;
typedef vector<vl> vll;
typedef vector<pi> vpi;
typedef vector<vpi> vpii;
typedef vector<pl> vpl;
typedef vector<cd> vcd;
typedef vector<pd> vpd;
typedef vector<bool> vb;
typedef vector<vb> vbb;
typedef std::string str;
typedef std::vector<str> vs;

#define x first
#define y second
#define debug(...) cout<<"["<<#__VA_ARGS__<<": "<<__VA_ARGS__<<"]\n"

const int MOD = 1000000007;
const ll INF = std::numeric_limits<ll>::max();
const int MX = 100101;
const ld PI = 3.14159265358979323846264338327950288419716939937510582097494L;

template<typename T>
pair<T, T> operator+(const pair<T, T> &a, const pair<T, T> &b) { return pair<T, T>(a.x + b.x, a.y + b.y); }
template<typename T>
pair<T, T> operator-(const pair<T, T> &a, const pair<T, T> &b) { return pair<T, T>(a.x - b.x, a.y - b.y); }
template<typename T>
T operator*(const pair<T, T> &a, const pair<T, T> &b) { return (a.x * b.x + a.y * b.y); }
template<typename T>
T operator^(const pair<T, T> &a, const pair<T, T> &b) { return (a.x * b.y - a.y * b.x); }

template<typename T>
void print(vector<T> vec, string name = "") {
	cout << name;
	for (auto u : vec)
		cout << u << ' ';
	cout << '\n';
}


str solve_puzzle(str s, vi c) {
	int N = (int)s.size();
	int K = (int)c.size();

	s.insert(s.begin(), ' ');
	c.insert(c.begin(), 0);

	vbb dp(N + 1, vb(K + 1, false));
	vii trues(K + 1);
	vi black(N + 1, 0);
	vi white(N + 1, 0);

	for (int i = 1; i <= N; ++i)
	{
		black[i] = black[i - 1] + int(s[i] == 'X');
		white[i] = white[i - 1] + int(s[i] == '_');
	}

	vi lastB(N + 1);
	vi lastW(N + 1);

	{
		int lb = -1;
		int lw = -1;
		for (int i = 0; i <= N; ++i)
		{
			if (s[i] == 'X') lb = i;
			if (s[i] == '_') lw = i;

			lastB[i] = lb;
			lastW[i] = lw;
		}
	}

	auto get = [](int a, int b, vi & vec) {
		return vec[b] - (a ? vec[a - 1] : 0);
	};

	dp[0][0] = true;
	trues[0].emplace_back(-1);

	// print(white);
	// print(black);
	for (int k = 1; k <= K; ++k)
	{
		for (int n = 1; n <= N; ++n)
		{
			if (s[n] == '_') continue;
			if (n - c[k] < 0) continue;
			if (get(n - c[k] + 1, n, white) > 0) continue;
			if (k == K and get(n + 1, N, black) > 0) continue;
			
			int lb = lastB[n - c[k]];

			auto it = lower_bound(trues[k - 1].begin(), trues[k - 1].end(), lb);
			// printf("k = %d, n = %d whites = %d\n", k, n, get(n - c[k], n, white));
			// printf("lb = %d, it = %d\n", lb, *it);
			if (it != trues[k - 1].end() and * it < n - c[k]) {
				dp[n][k] = true;
				trues[k].emplace_back(n);
			}
		}
	}

	// for (int i = 1; i <= K; ++i) print(trues[i]);

	vi yrB(N + 2, 0);
	vi yrW(N + 2, 0);

	{
		vb legal(N + 1, true);

		for (int k = K; k >= 1; --k)
		{
			vi newLegal(N + 2, 0);

			for (int n = 1; n <= N; ++n)
			{
				if (dp[n][k] and legal[n]) {
					yrB[n - c[k] + 1]++;
					yrB[n + 1]--;

					int lb = lastB[n - c[k]];

					auto it = lower_bound(trues[k - 1].begin(), trues[k - 1].end(), lb);
					// printf("k = %d, n = %d whites = %d\n", k, n, get(n - c[k], n, white));
					// printf("lb = %d, it = %d\n", lb, *it);
					if (it != trues[k - 1].end() and * it < n - c[k]) {

						yrW[*it + 1]++;
						yrW[n - c[k] + 1]--;

						newLegal[max(1, *it)]++;
						newLegal[n - c[k]]--;
					}
				}
			}
			for (int i = 1; i <= N; ++i)
			{
				newLegal[i] += newLegal[i - 1];
				legal[i] = bool(newLegal[i] > 0);
			}
		}
	}
	int pab = trues[K][0];

	yrW[pab + 1]++;

	// printf("pab = %d\n", pab);
	str ats(N, '?');


	for (int i = 1; i <= N; ++i)
	{
		yrW[i] += yrW[i - 1];
		yrB[i] += yrB[i - 1];

		if (s[i] != '.') {
			ats[i - 1] = s[i];
			continue;
		}

		if (yrB[i] > 0 and yrW[i] > 0) ats[i - 1] = '?';
		else if (yrW[i] > 0) ats[i - 1] = '_';
		else if (yrB[i] > 0) ats[i - 1] = 'X';
	}
	// print(yrW, "yrW: ");
	// print(yrB, "yrB: ");

	return ats;
}
# Verdict Execution time Memory Grader output
1 Correct 5 ms 256 KB n = 13, m = 1
2 Correct 5 ms 256 KB n = 18, m = 1
3 Correct 5 ms 256 KB n = 17, m = 1
4 Correct 5 ms 376 KB n = 1, m = 1
5 Correct 5 ms 376 KB n = 20, m = 1
6 Correct 5 ms 256 KB n = 20, m = 1
7 Correct 5 ms 376 KB n = 20, m = 1
# Verdict Execution time Memory Grader output
1 Correct 5 ms 256 KB n = 13, m = 1
2 Correct 5 ms 256 KB n = 18, m = 1
3 Correct 5 ms 256 KB n = 17, m = 1
4 Correct 5 ms 376 KB n = 1, m = 1
5 Correct 5 ms 376 KB n = 20, m = 1
6 Correct 5 ms 256 KB n = 20, m = 1
7 Correct 5 ms 376 KB n = 20, m = 1
8 Correct 5 ms 376 KB n = 20, m = 5
9 Correct 5 ms 256 KB n = 18, m = 3
10 Correct 5 ms 256 KB n = 17, m = 2
11 Correct 4 ms 256 KB n = 20, m = 2
12 Correct 5 ms 256 KB n = 17, m = 4
13 Correct 5 ms 256 KB n = 17, m = 6
14 Correct 5 ms 256 KB n = 17, m = 1
15 Correct 5 ms 256 KB n = 17, m = 4
16 Correct 5 ms 256 KB n = 13, m = 3
17 Correct 5 ms 248 KB n = 18, m = 4
18 Correct 5 ms 256 KB n = 20, m = 10
19 Correct 5 ms 256 KB n = 19, m = 10
# Verdict Execution time Memory Grader output
1 Correct 5 ms 256 KB n = 13, m = 1
2 Correct 5 ms 256 KB n = 18, m = 1
3 Correct 5 ms 256 KB n = 17, m = 1
4 Correct 5 ms 376 KB n = 1, m = 1
5 Correct 5 ms 376 KB n = 20, m = 1
6 Correct 5 ms 256 KB n = 20, m = 1
7 Correct 5 ms 376 KB n = 20, m = 1
8 Correct 5 ms 376 KB n = 20, m = 5
9 Correct 5 ms 256 KB n = 18, m = 3
10 Correct 5 ms 256 KB n = 17, m = 2
11 Correct 4 ms 256 KB n = 20, m = 2
12 Correct 5 ms 256 KB n = 17, m = 4
13 Correct 5 ms 256 KB n = 17, m = 6
14 Correct 5 ms 256 KB n = 17, m = 1
15 Correct 5 ms 256 KB n = 17, m = 4
16 Correct 5 ms 256 KB n = 13, m = 3
17 Correct 5 ms 248 KB n = 18, m = 4
18 Correct 5 ms 256 KB n = 20, m = 10
19 Correct 5 ms 256 KB n = 19, m = 10
20 Correct 5 ms 376 KB n = 100, m = 5
21 Correct 5 ms 256 KB n = 90, m = 3
22 Correct 5 ms 256 KB n = 86, m = 2
23 Correct 4 ms 256 KB n = 81, m = 4
24 Correct 5 ms 256 KB n = 89, m = 10
25 Correct 5 ms 376 KB n = 81, m = 23
26 Correct 5 ms 256 KB n = 86, m = 8
27 Correct 5 ms 256 KB n = 53, m = 22
28 Correct 5 ms 376 KB n = 89, m = 35
29 Correct 5 ms 256 KB n = 63, m = 25
30 Correct 5 ms 376 KB n = 100, m = 50
31 Correct 5 ms 376 KB n = 99, m = 50
# Verdict Execution time Memory Grader output
1 Correct 5 ms 256 KB n = 13, m = 1
2 Correct 5 ms 256 KB n = 18, m = 1
3 Correct 5 ms 256 KB n = 17, m = 1
4 Correct 5 ms 376 KB n = 1, m = 1
5 Correct 5 ms 376 KB n = 20, m = 1
6 Correct 5 ms 256 KB n = 20, m = 1
7 Correct 5 ms 376 KB n = 20, m = 1
8 Correct 5 ms 376 KB n = 20, m = 5
9 Correct 5 ms 256 KB n = 18, m = 3
10 Correct 5 ms 256 KB n = 17, m = 2
11 Correct 4 ms 256 KB n = 20, m = 2
12 Correct 5 ms 256 KB n = 17, m = 4
13 Correct 5 ms 256 KB n = 17, m = 6
14 Correct 5 ms 256 KB n = 17, m = 1
15 Correct 5 ms 256 KB n = 17, m = 4
16 Correct 5 ms 256 KB n = 13, m = 3
17 Correct 5 ms 248 KB n = 18, m = 4
18 Correct 5 ms 256 KB n = 20, m = 10
19 Correct 5 ms 256 KB n = 19, m = 10
20 Correct 5 ms 376 KB n = 100, m = 5
21 Correct 5 ms 256 KB n = 90, m = 3
22 Correct 5 ms 256 KB n = 86, m = 2
23 Correct 4 ms 256 KB n = 81, m = 4
24 Correct 5 ms 256 KB n = 89, m = 10
25 Correct 5 ms 376 KB n = 81, m = 23
26 Correct 5 ms 256 KB n = 86, m = 8
27 Correct 5 ms 256 KB n = 53, m = 22
28 Correct 5 ms 376 KB n = 89, m = 35
29 Correct 5 ms 256 KB n = 63, m = 25
30 Correct 5 ms 376 KB n = 100, m = 50
31 Correct 5 ms 376 KB n = 99, m = 50
32 Correct 5 ms 256 KB n = 13, m = 4
33 Correct 5 ms 256 KB n = 86, m = 2
34 Correct 5 ms 256 KB n = 88, m = 2
35 Correct 5 ms 376 KB n = 86, m = 2
36 Correct 5 ms 256 KB n = 81, m = 6
37 Correct 6 ms 376 KB n = 98, m = 7
38 Correct 5 ms 256 KB n = 92, m = 7
39 Correct 5 ms 376 KB n = 88, m = 21
40 Correct 5 ms 376 KB n = 90, m = 21
41 Correct 5 ms 376 KB n = 98, m = 22
# Verdict Execution time Memory Grader output
1 Correct 5 ms 256 KB n = 13, m = 1
2 Correct 5 ms 256 KB n = 18, m = 1
3 Correct 5 ms 256 KB n = 17, m = 1
4 Correct 5 ms 376 KB n = 1, m = 1
5 Correct 5 ms 376 KB n = 20, m = 1
6 Correct 5 ms 256 KB n = 20, m = 1
7 Correct 5 ms 376 KB n = 20, m = 1
8 Correct 5 ms 376 KB n = 20, m = 5
9 Correct 5 ms 256 KB n = 18, m = 3
10 Correct 5 ms 256 KB n = 17, m = 2
11 Correct 4 ms 256 KB n = 20, m = 2
12 Correct 5 ms 256 KB n = 17, m = 4
13 Correct 5 ms 256 KB n = 17, m = 6
14 Correct 5 ms 256 KB n = 17, m = 1
15 Correct 5 ms 256 KB n = 17, m = 4
16 Correct 5 ms 256 KB n = 13, m = 3
17 Correct 5 ms 248 KB n = 18, m = 4
18 Correct 5 ms 256 KB n = 20, m = 10
19 Correct 5 ms 256 KB n = 19, m = 10
20 Correct 5 ms 376 KB n = 100, m = 5
21 Correct 5 ms 256 KB n = 90, m = 3
22 Correct 5 ms 256 KB n = 86, m = 2
23 Correct 4 ms 256 KB n = 81, m = 4
24 Correct 5 ms 256 KB n = 89, m = 10
25 Correct 5 ms 376 KB n = 81, m = 23
26 Correct 5 ms 256 KB n = 86, m = 8
27 Correct 5 ms 256 KB n = 53, m = 22
28 Correct 5 ms 376 KB n = 89, m = 35
29 Correct 5 ms 256 KB n = 63, m = 25
30 Correct 5 ms 376 KB n = 100, m = 50
31 Correct 5 ms 376 KB n = 99, m = 50
32 Correct 5 ms 256 KB n = 13, m = 4
33 Correct 5 ms 256 KB n = 86, m = 2
34 Correct 5 ms 256 KB n = 88, m = 2
35 Correct 5 ms 376 KB n = 86, m = 2
36 Correct 5 ms 256 KB n = 81, m = 6
37 Correct 6 ms 376 KB n = 98, m = 7
38 Correct 5 ms 256 KB n = 92, m = 7
39 Correct 5 ms 376 KB n = 88, m = 21
40 Correct 5 ms 376 KB n = 90, m = 21
41 Correct 5 ms 376 KB n = 98, m = 22
42 Correct 5 ms 256 KB n = 11, m = 2
43 Correct 4 ms 256 KB n = 11, m = 2
44 Correct 5 ms 256 KB n = 13, m = 3
45 Correct 5 ms 256 KB n = 86, m = 2
46 Correct 4 ms 256 KB n = 81, m = 2
47 Correct 5 ms 360 KB n = 93, m = 2
48 Correct 5 ms 376 KB n = 81, m = 2
49 Correct 5 ms 256 KB n = 86, m = 2
50 Correct 5 ms 380 KB n = 90, m = 2
51 Correct 5 ms 376 KB n = 87, m = 2
52 Correct 5 ms 256 KB n = 97, m = 2
53 Correct 5 ms 376 KB n = 85, m = 2
54 Correct 5 ms 376 KB n = 88, m = 7
55 Correct 5 ms 376 KB n = 96, m = 7
56 Correct 5 ms 376 KB n = 85, m = 7
57 Correct 5 ms 376 KB n = 92, m = 7
58 Correct 5 ms 376 KB n = 92, m = 7
59 Correct 5 ms 376 KB n = 86, m = 7
60 Correct 5 ms 256 KB n = 87, m = 7
61 Correct 5 ms 376 KB n = 100, m = 7
62 Correct 5 ms 376 KB n = 100, m = 7
63 Correct 5 ms 376 KB n = 92, m = 21
64 Correct 5 ms 376 KB n = 93, m = 22
65 Correct 5 ms 256 KB n = 95, m = 22
66 Correct 5 ms 376 KB n = 98, m = 22
67 Correct 5 ms 376 KB n = 94, m = 22
68 Correct 5 ms 376 KB n = 93, m = 22
69 Correct 5 ms 376 KB n = 88, m = 21
70 Correct 5 ms 252 KB n = 83, m = 20
71 Correct 5 ms 376 KB n = 99, m = 23
72 Correct 5 ms 376 KB n = 96, m = 19
# Verdict Execution time Memory Grader output
1 Correct 5 ms 256 KB n = 13, m = 1
2 Correct 5 ms 256 KB n = 18, m = 1
3 Correct 5 ms 256 KB n = 17, m = 1
4 Correct 5 ms 376 KB n = 1, m = 1
5 Correct 5 ms 376 KB n = 20, m = 1
6 Correct 5 ms 256 KB n = 20, m = 1
7 Correct 5 ms 376 KB n = 20, m = 1
8 Correct 5 ms 376 KB n = 20, m = 5
9 Correct 5 ms 256 KB n = 18, m = 3
10 Correct 5 ms 256 KB n = 17, m = 2
11 Correct 4 ms 256 KB n = 20, m = 2
12 Correct 5 ms 256 KB n = 17, m = 4
13 Correct 5 ms 256 KB n = 17, m = 6
14 Correct 5 ms 256 KB n = 17, m = 1
15 Correct 5 ms 256 KB n = 17, m = 4
16 Correct 5 ms 256 KB n = 13, m = 3
17 Correct 5 ms 248 KB n = 18, m = 4
18 Correct 5 ms 256 KB n = 20, m = 10
19 Correct 5 ms 256 KB n = 19, m = 10
20 Correct 5 ms 376 KB n = 100, m = 5
21 Correct 5 ms 256 KB n = 90, m = 3
22 Correct 5 ms 256 KB n = 86, m = 2
23 Correct 4 ms 256 KB n = 81, m = 4
24 Correct 5 ms 256 KB n = 89, m = 10
25 Correct 5 ms 376 KB n = 81, m = 23
26 Correct 5 ms 256 KB n = 86, m = 8
27 Correct 5 ms 256 KB n = 53, m = 22
28 Correct 5 ms 376 KB n = 89, m = 35
29 Correct 5 ms 256 KB n = 63, m = 25
30 Correct 5 ms 376 KB n = 100, m = 50
31 Correct 5 ms 376 KB n = 99, m = 50
32 Correct 5 ms 256 KB n = 13, m = 4
33 Correct 5 ms 256 KB n = 86, m = 2
34 Correct 5 ms 256 KB n = 88, m = 2
35 Correct 5 ms 376 KB n = 86, m = 2
36 Correct 5 ms 256 KB n = 81, m = 6
37 Correct 6 ms 376 KB n = 98, m = 7
38 Correct 5 ms 256 KB n = 92, m = 7
39 Correct 5 ms 376 KB n = 88, m = 21
40 Correct 5 ms 376 KB n = 90, m = 21
41 Correct 5 ms 376 KB n = 98, m = 22
42 Correct 5 ms 256 KB n = 11, m = 2
43 Correct 4 ms 256 KB n = 11, m = 2
44 Correct 5 ms 256 KB n = 13, m = 3
45 Correct 5 ms 256 KB n = 86, m = 2
46 Correct 4 ms 256 KB n = 81, m = 2
47 Correct 5 ms 360 KB n = 93, m = 2
48 Correct 5 ms 376 KB n = 81, m = 2
49 Correct 5 ms 256 KB n = 86, m = 2
50 Correct 5 ms 380 KB n = 90, m = 2
51 Correct 5 ms 376 KB n = 87, m = 2
52 Correct 5 ms 256 KB n = 97, m = 2
53 Correct 5 ms 376 KB n = 85, m = 2
54 Correct 5 ms 376 KB n = 88, m = 7
55 Correct 5 ms 376 KB n = 96, m = 7
56 Correct 5 ms 376 KB n = 85, m = 7
57 Correct 5 ms 376 KB n = 92, m = 7
58 Correct 5 ms 376 KB n = 92, m = 7
59 Correct 5 ms 376 KB n = 86, m = 7
60 Correct 5 ms 256 KB n = 87, m = 7
61 Correct 5 ms 376 KB n = 100, m = 7
62 Correct 5 ms 376 KB n = 100, m = 7
63 Correct 5 ms 376 KB n = 92, m = 21
64 Correct 5 ms 376 KB n = 93, m = 22
65 Correct 5 ms 256 KB n = 95, m = 22
66 Correct 5 ms 376 KB n = 98, m = 22
67 Correct 5 ms 376 KB n = 94, m = 22
68 Correct 5 ms 376 KB n = 93, m = 22
69 Correct 5 ms 376 KB n = 88, m = 21
70 Correct 5 ms 252 KB n = 83, m = 20
71 Correct 5 ms 376 KB n = 99, m = 23
72 Correct 5 ms 376 KB n = 96, m = 19
73 Correct 5 ms 760 KB n = 4825, m = 5
74 Correct 5 ms 760 KB n = 4384, m = 5
75 Correct 6 ms 760 KB n = 4528, m = 5
76 Correct 5 ms 760 KB n = 4980, m = 5
77 Correct 6 ms 888 KB n = 4730, m = 5
78 Correct 5 ms 764 KB n = 4784, m = 5
79 Correct 7 ms 760 KB n = 4875, m = 5
80 Correct 6 ms 760 KB n = 4576, m = 5
81 Correct 6 ms 760 KB n = 4297, m = 5
82 Correct 8 ms 748 KB n = 4662, m = 48
83 Correct 9 ms 760 KB n = 4753, m = 49
84 Correct 8 ms 760 KB n = 4148, m = 46
85 Correct 9 ms 760 KB n = 4906, m = 50
86 Correct 9 ms 888 KB n = 4967, m = 50
87 Correct 10 ms 888 KB n = 4828, m = 49
88 Correct 8 ms 760 KB n = 4105, m = 45
89 Correct 9 ms 888 KB n = 4954, m = 50
90 Correct 11 ms 1144 KB n = 4884, m = 49
91 Correct 10 ms 760 KB n = 4307, m = 100
92 Correct 11 ms 760 KB n = 4668, m = 100
93 Correct 13 ms 888 KB n = 4647, m = 100
94 Correct 11 ms 760 KB n = 4372, m = 100
95 Correct 12 ms 888 KB n = 4791, m = 100
96 Correct 14 ms 1016 KB n = 4029, m = 100
97 Correct 11 ms 760 KB n = 4439, m = 100
98 Correct 12 ms 1144 KB n = 4018, m = 100
99 Correct 20 ms 1656 KB n = 4979, m = 100
100 Correct 13 ms 1008 KB n = 4996, m = 89
# Verdict Execution time Memory Grader output
1 Correct 5 ms 256 KB n = 13, m = 1
2 Correct 5 ms 256 KB n = 18, m = 1
3 Correct 5 ms 256 KB n = 17, m = 1
4 Correct 5 ms 376 KB n = 1, m = 1
5 Correct 5 ms 376 KB n = 20, m = 1
6 Correct 5 ms 256 KB n = 20, m = 1
7 Correct 5 ms 376 KB n = 20, m = 1
8 Correct 5 ms 376 KB n = 20, m = 5
9 Correct 5 ms 256 KB n = 18, m = 3
10 Correct 5 ms 256 KB n = 17, m = 2
11 Correct 4 ms 256 KB n = 20, m = 2
12 Correct 5 ms 256 KB n = 17, m = 4
13 Correct 5 ms 256 KB n = 17, m = 6
14 Correct 5 ms 256 KB n = 17, m = 1
15 Correct 5 ms 256 KB n = 17, m = 4
16 Correct 5 ms 256 KB n = 13, m = 3
17 Correct 5 ms 248 KB n = 18, m = 4
18 Correct 5 ms 256 KB n = 20, m = 10
19 Correct 5 ms 256 KB n = 19, m = 10
20 Correct 5 ms 376 KB n = 100, m = 5
21 Correct 5 ms 256 KB n = 90, m = 3
22 Correct 5 ms 256 KB n = 86, m = 2
23 Correct 4 ms 256 KB n = 81, m = 4
24 Correct 5 ms 256 KB n = 89, m = 10
25 Correct 5 ms 376 KB n = 81, m = 23
26 Correct 5 ms 256 KB n = 86, m = 8
27 Correct 5 ms 256 KB n = 53, m = 22
28 Correct 5 ms 376 KB n = 89, m = 35
29 Correct 5 ms 256 KB n = 63, m = 25
30 Correct 5 ms 376 KB n = 100, m = 50
31 Correct 5 ms 376 KB n = 99, m = 50
32 Correct 5 ms 256 KB n = 13, m = 4
33 Correct 5 ms 256 KB n = 86, m = 2
34 Correct 5 ms 256 KB n = 88, m = 2
35 Correct 5 ms 376 KB n = 86, m = 2
36 Correct 5 ms 256 KB n = 81, m = 6
37 Correct 6 ms 376 KB n = 98, m = 7
38 Correct 5 ms 256 KB n = 92, m = 7
39 Correct 5 ms 376 KB n = 88, m = 21
40 Correct 5 ms 376 KB n = 90, m = 21
41 Correct 5 ms 376 KB n = 98, m = 22
42 Correct 5 ms 256 KB n = 11, m = 2
43 Correct 4 ms 256 KB n = 11, m = 2
44 Correct 5 ms 256 KB n = 13, m = 3
45 Correct 5 ms 256 KB n = 86, m = 2
46 Correct 4 ms 256 KB n = 81, m = 2
47 Correct 5 ms 360 KB n = 93, m = 2
48 Correct 5 ms 376 KB n = 81, m = 2
49 Correct 5 ms 256 KB n = 86, m = 2
50 Correct 5 ms 380 KB n = 90, m = 2
51 Correct 5 ms 376 KB n = 87, m = 2
52 Correct 5 ms 256 KB n = 97, m = 2
53 Correct 5 ms 376 KB n = 85, m = 2
54 Correct 5 ms 376 KB n = 88, m = 7
55 Correct 5 ms 376 KB n = 96, m = 7
56 Correct 5 ms 376 KB n = 85, m = 7
57 Correct 5 ms 376 KB n = 92, m = 7
58 Correct 5 ms 376 KB n = 92, m = 7
59 Correct 5 ms 376 KB n = 86, m = 7
60 Correct 5 ms 256 KB n = 87, m = 7
61 Correct 5 ms 376 KB n = 100, m = 7
62 Correct 5 ms 376 KB n = 100, m = 7
63 Correct 5 ms 376 KB n = 92, m = 21
64 Correct 5 ms 376 KB n = 93, m = 22
65 Correct 5 ms 256 KB n = 95, m = 22
66 Correct 5 ms 376 KB n = 98, m = 22
67 Correct 5 ms 376 KB n = 94, m = 22
68 Correct 5 ms 376 KB n = 93, m = 22
69 Correct 5 ms 376 KB n = 88, m = 21
70 Correct 5 ms 252 KB n = 83, m = 20
71 Correct 5 ms 376 KB n = 99, m = 23
72 Correct 5 ms 376 KB n = 96, m = 19
73 Correct 5 ms 760 KB n = 4825, m = 5
74 Correct 5 ms 760 KB n = 4384, m = 5
75 Correct 6 ms 760 KB n = 4528, m = 5
76 Correct 5 ms 760 KB n = 4980, m = 5
77 Correct 6 ms 888 KB n = 4730, m = 5
78 Correct 5 ms 764 KB n = 4784, m = 5
79 Correct 7 ms 760 KB n = 4875, m = 5
80 Correct 6 ms 760 KB n = 4576, m = 5
81 Correct 6 ms 760 KB n = 4297, m = 5
82 Correct 8 ms 748 KB n = 4662, m = 48
83 Correct 9 ms 760 KB n = 4753, m = 49
84 Correct 8 ms 760 KB n = 4148, m = 46
85 Correct 9 ms 760 KB n = 4906, m = 50
86 Correct 9 ms 888 KB n = 4967, m = 50
87 Correct 10 ms 888 KB n = 4828, m = 49
88 Correct 8 ms 760 KB n = 4105, m = 45
89 Correct 9 ms 888 KB n = 4954, m = 50
90 Correct 11 ms 1144 KB n = 4884, m = 49
91 Correct 10 ms 760 KB n = 4307, m = 100
92 Correct 11 ms 760 KB n = 4668, m = 100
93 Correct 13 ms 888 KB n = 4647, m = 100
94 Correct 11 ms 760 KB n = 4372, m = 100
95 Correct 12 ms 888 KB n = 4791, m = 100
96 Correct 14 ms 1016 KB n = 4029, m = 100
97 Correct 11 ms 760 KB n = 4439, m = 100
98 Correct 12 ms 1144 KB n = 4018, m = 100
99 Correct 20 ms 1656 KB n = 4979, m = 100
100 Correct 13 ms 1008 KB n = 4996, m = 89
101 Correct 57 ms 18572 KB n = 178952, m = 10
102 Correct 56 ms 18760 KB n = 180674, m = 10
103 Correct 50 ms 17352 KB n = 167639, m = 10
104 Correct 56 ms 17996 KB n = 172892, m = 10
105 Correct 51 ms 17488 KB n = 168125, m = 10
106 Correct 51 ms 17360 KB n = 166514, m = 10
107 Correct 60 ms 19060 KB n = 183874, m = 10
108 Correct 59 ms 20156 KB n = 194560, m = 10
109 Correct 53 ms 17872 KB n = 171994, m = 10
110 Correct 266 ms 17236 KB n = 165207, m = 100
111 Correct 286 ms 19644 KB n = 188459, m = 100
112 Correct 248 ms 16984 KB n = 162137, m = 100
113 Correct 288 ms 17620 KB n = 169691, m = 100
114 Correct 283 ms 19520 KB n = 187642, m = 100
115 Correct 260 ms 17616 KB n = 168456, m = 100
116 Correct 305 ms 18816 KB n = 180980, m = 100
117 Correct 297 ms 19916 KB n = 191687, m = 100
118 Correct 267 ms 17364 KB n = 166437, m = 100
119 Correct 301 ms 19392 KB n = 186520, m = 100
120 Correct 251 ms 17364 KB n = 166675, m = 100
121 Correct 289 ms 19552 KB n = 187725, m = 100
122 Correct 259 ms 16736 KB n = 161455, m = 100
123 Correct 297 ms 20032 KB n = 192977, m = 100
124 Correct 294 ms 20036 KB n = 192612, m = 100
125 Correct 320 ms 20408 KB n = 196512, m = 100
126 Correct 305 ms 20660 KB n = 198968, m = 100
127 Correct 259 ms 17364 KB n = 166659, m = 100
128 Correct 225 ms 26416 KB n = 199997, m = 34
129 Correct 33 ms 20660 KB n = 200000, m = 1
130 Correct 56 ms 21676 KB n = 200000, m = 1
131 Correct 1358 ms 99372 KB n = 199999, m = 100
132 Correct 599 ms 59692 KB n = 199999, m = 100
133 Correct 33 ms 20660 KB n = 200000, m = 1