프로그래머스 133499 옹알이 (2)

Jmnote (토론 | 기여)님의 2023년 11월 29일 (수) 21:27 판 (새 문서: ==개요== {{프로그래머스|레벨=1|페이지=2|분류=연습문제}} ==같이 보기== * 프로그래머스 120956 옹알이 (1) ==C++== <syntaxhighlight lang='cpp'> #incl...)
(차이) ← 이전 판 | 최신판 (차이) | 다음 판 → (차이)

1 개요

프로그래머스 133499 옹알이 (2)

2 같이 보기

3 C++

#include <string>
#include <vector>
using namespace std;

void str_replace_all(string& s, string const& search, string const& replace) {
    string buf;
    size_t pos = 0;
    size_t prevPos;
    buf.reserve(s.size());
    while (true) {
        prevPos = pos;
        pos = s.find(search, pos);
        if (pos == string::npos) {
            break;
        }
        buf.append(s, prevPos, pos - prevPos);
        buf += replace;
        pos += search.size();
    }
    buf.append(s, prevPos, s.size() - prevPos);
    s.swap(buf);
}

bool possible(string message) {
    str_replace_all(message, "aya", "1");
    str_replace_all(message, "ye", "2");
    str_replace_all(message, "woo", "3");
    str_replace_all(message, "ma", "4");
    str_replace_all(message, "11", "X");
    str_replace_all(message, "22", "X");
    str_replace_all(message, "33", "X");
    str_replace_all(message, "44", "X");
    str_replace_all(message, "1", "");
    str_replace_all(message, "2", "");
    str_replace_all(message, "3", "");
    str_replace_all(message, "4", "");
    return message.length() == 0;
}

int solution(vector<string> babbling) {
    int answer = 0;
    for(string& message: babbling) {
        if(possible(message)) answer++;
    }
    return answer;
}
문서 댓글 ({{ doc_comments.length }})
{{ comment.name }} {{ comment.created | snstime }}