C C++/알고리즘풀이

[백준] 12871

치춘 2023. 9. 21. 22:52

무한 문자열

문제

문자열 s가 있을 때, f(s)는 s를 무한번 붙인 문자열로 정의한다. 예를 들어, s = "abc" 인 경우에 f(s) = "abcabcabcabc..."가 된다.

다른 문자열 s와 t가 있을 때, f(s)와 f(t)가 같은 문자열인 경우가 있다. 예를 들어서, s = "abc", t = "abcabc"인 경우에 f(s)와 f(t)는 같은 문자열을 만든다.

s와 t가 주어졌을 때, f(s)와 f(t)가 같은 문자열을 만드는지 아닌지 구하는 프로그램을 작성하시오.

입력

첫째 줄에 s, 둘째 줄에 t가 주어진다. 두 문자열 s와 t의 길이는 50보다 작거나 같은 자연수이고, 알파벳 소문자로만 이루어져 있다.

출력

첫째 줄에 f(s)와 f(t)가 같으면 1을, 다르면 0을 출력한다.

풀이

#include <iostream>
#include <string>

int comp(std::string min, std::string max, int minlen, int maxlen, int lcm) {
    int minrepeat = lcm / minlen;
    int maxrepeat = lcm / maxlen;
    std::string mintemp = "";
    std::string maxtemp = "";

    while (minrepeat-- > 0)
        mintemp += min;
    while (maxrepeat-- > 0)
        maxtemp += max;

    return mintemp == maxtemp;
}

int lcm(int a, int b) {
    int c;
    int aTemp = a, bTemp = b;

    while (b != 0) {
        c = a % b;
        a = b;
        b = c;
    }
    return aTemp * bTemp / a;
}

int main(void) {
    std::string s, t;
    int slen, tlen, lcmlen;

    std::cin >> s >> t;
    slen = s.length();
    tlen = t.length();
    lcmlen = lcm(slen, tlen);
    if (slen > tlen)
        std::cout << comp(t, s, tlen, slen, lcmlen);
    else
        std::cout << comp(s, t, slen, tlen, lcmlen);
}

반성회

처음엔 길이가 짧은 문자열을 반복해서 길이가 긴 문자열을 만들 수 있으면 1인 줄 알았는데

그렇게 하면 aa, aaa 같은 반례에서 걸린다 (짧은 문자열로 긴 문자열을 만들 순 없지만 무한히 반복하면 두개가 같아짐)

그래서 최소공배수를 구해서 그 길이가 되게끔 반복시켜 비교하는 방식으로 풀었다