[프로그래머스/C++]Lv.0 - 문자열 밀기

YH J·2023년 4월 17일
0

프로그래머스

목록 보기
3/168

문제 링크

https://school.programmers.co.kr/learn/courses/30/lessons/120921

내 풀이

A를 한 글자 한 글자 밀어가면서 B랑 비교하여 그 인덱스를 리턴함

내 코드

#include <string>
#include <vector>

using namespace std;

int solution(string A, string B) {
    int answer = -1;
    for(int i = 0; i < A.size(); i++)
    {
        if (A == B)            
        {
            answer = i;
            break;
        }
        char s = A[A.size()-1];
        A = A.substr(0, A.size()-1);
        A = s + A;
    }
    return answer;
}

다른 사람의 풀이

#include <string>

using namespace std;

int solution(string A, string B)
{
    B += B;
    return B.find(A);
}

다른 사람의 풀이 해석

B를 2개 이어붙인 다음 거기서 A를 find()함.있다면 A가 시작하는 위치를 반환하고 없으면 -1을 반환하므로 간결하고 가장 쉬운 방법

profile
게임 개발자 지망생

0개의 댓글