[백준] PS/Java [실랜디]

[백준 2607] 비슷한 단어 - JAVA

SH3542 2025. 5. 4. 09:09

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);
  }
}