접근

https://www.acmicpc.net/problem/9177

 

9177번: 단어 섞기

입력의 첫 번째 줄에는 1부터 1000까지의 양의 정수 하나가 주어지며 데이터 집합의 개수를 뜻한다. 각 데이터집합의 처리과정은 동일하다고 하자. 각 데이터집합에 대해, 세 개의 단어로 이루어

www.acmicpc.net

처음엔 당연히 1번, 2번, 3번 문자열의 인덱스를 i, j, k로 두고 string[1][i]와 string[3][k]가 일치한다면 i 와 k 를 1씩 늘려주면 그냥 풀리는 문제라고 생각했는데, string[1][i] 와 string[2][j], string[3][k]가 동시에 일치하는 경우를 모두 탐색해야 하기 때문에 두개 모두 탐색하기 위하여 bfs를 이용하게 되었다.

bfs 알고리즘을 이용하면서 큐에 {i, j, k} 를 추가하면서 string[1][i]와 string[3][k]가 일치한다면 {i + 1, j, k + 1} 을 큐에 추가해주고 반대로 string[2][j]와 string[3][k]가 일치한다면 {i, j + 1, k + 1} 를 큐에 추가, 그리고 string[1][i] 와 string[2][j], string[3][k]가 모두 일치한다면 두 가지 모두 추가하여 모든 경우를 빠짐 없이 탐색해 줄 수 있다. 그리고 그렇게 분화될 때 같은 경우를 중복 탐색하지 않기 위하여 visited[i][j] 배열을 이용해주었다.

코드

#include <cstring>
#include <iostream>
#include <queue>
#include <string>

using namespace std;

#define endl '\n'
#define MAX_L 201

struct info {
    int first;
    int second;
    int third;
};

int N;
string Data[3];
int visited[MAX_L][MAX_L];

int bfs() {
    memset(visited, 0, sizeof(visited));
    queue<info> Q;
    Q.push({0, 0, 0});
    visited[0][0] = 1;
    while (!Q.empty()) {
        int first = Q.front().first;
        int second = Q.front().second;
        int third = Q.front().third;
        Q.pop();
        if (third == Data[2].length()) return 1;
        // third 인덱스에 해당하는 문자가 first 인덱스 문자, second 인덱스 문자와 동시에 일치할 경우 두가지 모두 큐에 넣어 탐색해준다.
        if (first < Data[0].length() && Data[0][first] == Data[2][third] && visited[first + 1][second] == 0) {
            Q.push({first + 1, second, third + 1});
            visited[first + 1][second] = 1;
        }
        if (second < Data[1].length() && Data[1][second] == Data[2][third] && visited[first][second + 1] == 0) {
            Q.push({first, second + 1, third + 1});
            visited[first][second + 1] = 1;
        }
    }
    return 0;
}

int main(int argc, char** argv) {
    // freopen 주석 처리
    freopen("input.txt", "r", stdin);

    cin >> N;
    for (int i = 1; i <= N; i++) {
        cin >> Data[0] >> Data[1] >> Data[2];
        string ans;
        if (bfs()) {
            ans = "yes";
        } else {
            ans = "no";
        }
        cout << "Data set " << i << ": " << ans << endl;
    }

    return 0;
}

더 생각해 볼 것?

...

코드나 내용 관련 조언, 부족한 점 및 질문 언제든 환영합니다!

반응형

'코딩 > 백준 (C++)' 카테고리의 다른 글

백준 5022번: 연결 (C++)  (0) 2022.05.14
백준 1019번: 책 페이지 (C++)  (0) 2022.05.08
백준 5213번: 과외맨 (C++)  (0) 2022.05.07
백준 12886: 돌 그룹 (C++)  (0) 2022.05.07
백준 3108번: 로고 (C++)  (0) 2022.05.06
  • 네이버 블러그 공유하기
  • 네이버 밴드에 공유하기
  • 페이스북 공유하기
  • 카카오스토리 공유하기