알고리즘/Codeforces
R621(Div.1+Div.2) C. Cow and Message
세진짱
2020. 2. 19. 10:35
A,B,C중에 오히려 가장 쉬운 문제가 아니였나 싶다(?)
문제 자체 이해는 어려웠다
S라는 문자열 안에서 등차수열로 이루어진 T라는 문자열을 숨겼다
이 때 문자열 T의 수들 중 최댓값을 찾는 문제다
생각하다보면 문제가 쉬워진다
한번 정리를 해보자
1. 길이가 1일 때 => max(alpha[26]) 중 하나다
2. 길이가 2일 때 => for문을 통해 입력받으면서 보면 된다max(d[26][26])
3. 길이가 3일 때 => 여기부터 생각해봐야한다 꼭 봐야할까?
길이가 3이상이라면 길이가 2인것들을 무조건 포함해야만 만들 수 있다
따라서 볼 필요가 없다! 2까지만 보면 된다!
그럼 바로 쉬운문제로 변한다!
문제에서 필요로 하는것들만 뽑아내는 능력이 이럴때 쓰이는건가..!
이 문제는 쉬워서 다행히 잘 보였다..!
소스코드
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
#include <iostream>
#include <algorithm>
#include <string>
using namespace std;
#define ll long long
string s;
ll alpha[26];
ll d[26][26];
int main() {
cin >> s;
int sz = s.size();
for (int i = 0; i < sz; i++) {
for (int j = 0; j < 26; j++) {
if (alpha[j]) d[j][s[i] - 'a'] += alpha[j];
}
alpha[s[i] - 'a']++;
}
ll ans = 0;
for (int i = 0; i < 26; i++) ans = max(ans, alpha[i]);
for (int i = 0; i < 26; i++) {
for (int j = 0; j < 26; j++) {
ans = max(ans, d[i][j]);
}
}
printf("%lld\n", ans);
}
|