Skip to content

Commit 4cb8b97

Browse files
committed
21/03/03 Codeforces Educational Round 105
- a: stack, brute force - b: math
1 parent cc576f3 commit 4cb8b97

File tree

3 files changed

+128
-0
lines changed

3 files changed

+128
-0
lines changed

codeforces/edu/105/a.cpp

Lines changed: 43 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,43 @@
1+
#include <iostream>
2+
#include <string>
3+
4+
using namespace std;
5+
6+
int main() {
7+
int t;
8+
for(cin >> t; t > 0; t--) {
9+
string s;
10+
cin >> s;
11+
12+
int cnt[3] = {0, 0, 0};
13+
for(char ch: s) cnt[ch - 'A']++;
14+
15+
char bracket[3] = {')', ')', ')'};
16+
bracket[s[0] - 'A'] = '(';
17+
18+
bool ans = false;
19+
for(int i = 0; i < 3 && !ans; i++) {
20+
if(cnt[i] == cnt[(i + 1) % 3] + cnt[(i + 2) % 3]) {
21+
ans = true;
22+
if(bracket[i] == '(') bracket[(i + 1) % 3] = bracket[(i + 2) % 3] = ')';
23+
else {
24+
bracket[i] = ')';
25+
bracket[(i + 1) % 3] = bracket[(i + 2) % 3] = '(';
26+
}
27+
}
28+
}
29+
30+
int st = 0;
31+
for(int i = 0; i < s.size() && ans; i++) {
32+
char ch = bracket[s[i] - 'A'];
33+
if(ch == '(') st++;
34+
else if(st == 0) ans = false;
35+
else st--;
36+
}
37+
38+
if(ans && st == 0) cout << "YES\n";
39+
else cout << "NO\n";
40+
}
41+
42+
return 0;
43+
}

codeforces/edu/105/b.cpp

Lines changed: 25 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,25 @@
1+
#include <iostream>
2+
#include <algorithm>
3+
4+
using namespace std;
5+
6+
int main() {
7+
int t;
8+
for(cin >> t; t > 0; t--) {
9+
int n, colored[4];
10+
cin >> n;
11+
for(int i = 0; i < 4; i++) cin >> colored[i];
12+
13+
bool ans = true;
14+
for(int i = 0; i < 4 && ans; i++) {
15+
int prev = i, here = (i + 1) % 4, next = (i + 2) % 4, opposite = (i + 3) % 4;
16+
if(colored[here] <= n - 2) continue;
17+
else {
18+
ans = max(colored[here] - n + 2, 0) + max(colored[opposite] - n + 2, 0) <= min(colored[prev], 2) + min(colored[next], 2);
19+
if(colored[here] == n) ans = ans && colored[prev] > 0 && colored[next] > 0;
20+
}
21+
}
22+
23+
cout << (ans ? "YES" : "NO") << '\n';
24+
}
25+
}

codeforces/edu/105/c.cpp

Lines changed: 60 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,60 @@
1+
#include <iostream>
2+
#include <vector>
3+
#include <algorithm>
4+
#include <queue>
5+
6+
using namespace std;
7+
8+
int solve(vector<int> &a, vector<int> &b) {
9+
int ans = 0, nbox = 1, pivot = 0, match = 0;
10+
vector<int> consecutive(b.size());
11+
vector<bool> matched(a.size(), false);
12+
13+
consecutive[b.size() - 1] = 1;
14+
for(int i = b.size() - 2; i >= 0; i--) {
15+
if(b[i] + 1 == b[i + 1])
16+
consecutive[i] = consecutive[i + 1] + 1;
17+
else
18+
consecutive[i] = 1;
19+
}
20+
21+
for(int i = 0; i < a.size(); i++) {
22+
if(binary_search(b.begin(), b.end(), a[i])) {
23+
matched[i] = true;
24+
match++;
25+
}
26+
}
27+
28+
ans = match;
29+
queue<int> q;
30+
while(pivot < b.size()) {
31+
32+
}
33+
34+
return ans;
35+
}
36+
37+
int main() {
38+
int t;
39+
for(cin >> t; t > 0; t--) {
40+
int n, m;
41+
cin >> n >> m;
42+
43+
vector<int> ap, an, bp, bn;
44+
for(int i = 0; i < n; i++) {
45+
int num;
46+
cin >> num;
47+
48+
if(num > 0) ap.push_back(num);
49+
else an.push_back(num);
50+
}
51+
52+
for(int i = 0; i < m; i++) {
53+
int num;
54+
cin >> num;
55+
56+
if(num > 0) bp.push_back(num);
57+
else bn.push_back(num);
58+
}
59+
}
60+
}

0 commit comments

Comments
 (0)