https://www.acmicpc.net/problem/2607
한 문자를 빼거나/더하거나/교체할 수 있을 때, 두 문자를 이루는 알파벳 개수가 같은지 판별하는 문제
생각할 케이스가 많아서 까다로웠다.
내가 세운 동등 비교 판별식은 이렇다.
원본 문자열 a, 비교 문자열 b
어떤 알파벳의 개수가,
1. 2개 이상 차이나면 같지 않다.
2. 1개 더 많은 것이 a and b에서 한 번 일어나는 것은 괜찮다 (교체 동작)
3. 1개 더 많은 것이 a or b에서 한 번 일어나는 것은 괜찮다. (빼기/더하기 동작)
4. 모두 차이나지 않는 것은 괜찮다. (동일)
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
class Main {
public static void main(String[] args) throws IOException {
int ans = 0;
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int N = Integer.parseInt(br.readLine());
String s = br.readLine();
byte[] a = new byte[100];
for (int i = 0; i < s.length(); i++) {
a[s.charAt(i)]++;
}
for (int t = 0; t < N - 1; t++) {
String c = br.readLine();
byte[] b = new byte[100];
for (int i = 0; i < c.length(); i++) {
b[c.charAt(i)]++;
}
int aCnt = 0;
int bCnt = 0;
boolean bl = true;
for (int i = 'A'; i <= 'Z'; i++) {
if (Math.abs(a[i] - b[i]) > 1) {
bl = false;
break;
}
if (a[i] + 1 == b[i]) {
aCnt++;
} else if (a[i] == b[i] + 1) {
bCnt++;
}
}
if (bl && ((aCnt == 0 && bCnt == 1) ||
(aCnt == 1 && bCnt == 0) ||
(aCnt == 0 && bCnt == 0) ||
(aCnt == 1 && bCnt == 1))) {
ans++;
}
}
System.out.println(ans);
}
}
'[백준] PS > Java [실랜디]' 카테고리의 다른 글
[백준 2799] 블라인드 - JAVA (0) | 2025.05.04 |
---|---|
[백준 2697] 다음수 구하기 - JAVA (1) | 2025.05.04 |
[백준 2865] 나는 위대한 슈퍼스타K - JAVA (0) | 2025.05.04 |
[백준 2841] 외계인의 기타 연주 - JAVA (0) | 2025.05.04 |
[백준 3372] 보드 점프 - JAVA (0) | 2025.05.04 |