본문 바로가기
프로그래머스 코딩테스트 문제/Level 1

[프로그래머스] - 가장 가까운 같은 글자(C#)

by jyppro 2023. 8. 28.

가장 가까운 같은 글자

오늘은 "가장 가까운 같은 글자" 문제를 풀어보도록 하겠습니다. 이제 프로그래머스 레벨1의 문제도 거의 다 살펴보았습니다.

 

문제 설명

문자열 s가 주어졌을 때, s의 각 위치마다 자신보다 앞에 나왔으면서, 자신과 가장 가까운 곳에 있는 같은 글자가 어디 있는지 알고 싶습니다.
예를 들어, s="banana"라고 할 때,  각 글자들을 왼쪽부터 오른쪽으로 읽어 나가면서 다음과 같이 진행할 수 있습니다.

b는 처음 나왔기 때문에 자신의 앞에 같은 글자가 없습니다. 이는 -1로 표현합니다.
a는 처음 나왔기 때문에 자신의 앞에 같은 글자가 없습니다. 이는 -1로 표현합니다.
n은 처음 나왔기 때문에 자신의 앞에 같은 글자가 없습니다. 이는 -1로 표현합니다.
a는 자신보다 두 칸 앞에 a가 있습니다. 이는 2로 표현합니다.
n도 자신보다 두 칸 앞에 n이 있습니다. 이는 2로 표현합니다.
a는 자신보다 두 칸, 네 칸 앞에 a가 있습니다. 이 중 가까운 것은 두 칸 앞이고, 이는 2로 표현합니다.
따라서 최종 결과물은 [-1, -1, -1, 2, 2, 2]가 됩니다.

문자열 s이 주어질 때, 위와 같이 정의된 연산을 수행하는 함수 solution을 완성해주세요.

 

제한 사항

  • 1 ≤ s의 길이 ≤ 10,000
  • s은 영어 소문자로만 이루어져 있습니다.

 

입출력 예

s result
"banana" [-1, -1, -1, 2, 2, 2]
"foobar" [-1, -1, 1, -1, -1, -1]

 

입출력 예 설명

입출력 예 #1
지문과 같습니다.

입출력 예 #2
설명 생략

 

시작 코드

using System;

public class Solution {
    public int[] solution(string s) {
        int[] answer = new int[] {};
        return answer;
    }
}

 

나의 풀이

public class Solution {
    public int[] solution(string s) {
        int[] answer = new int[s.Length];
        int index = -1;
        
        for(int i = 0; i < s.Length; i++)
        {
            index = -1;
            for(int j = i - 1; j >= 0; j--)
            {
                if(s[i] == s[j])
                {
                    index = i - j;
                    break;
                }
            }
            answer[i] = index;
        }
        return answer;
    }
}

 

코드 분석

string 타입의 s가 주어지며 코드가 시작됩니다. int형 배열 answer의 길이를 s의 길이로 설정하고, int형으로 index를 만들어 -1로 선언해줍니다. 이후 이중for문을 작성합니다. 첫번째 for문은 0에서 s의 길이까지, 두번째는 첫번째 for문에서 0으로 사용된 i에서 1을 뺀 j부터 j가 0보다 크거나 같은 수가 될때까지 j를 빼줍니다. 첫번째 for문에서 두번째로 넘어가기 전에 index를 -1로 초기화 해주고, 두번째 for문 안에서 s[i]와 s[j]를 비교하여 같다면, index에 i - j를 넣어주고 빠져나옵니다.

이후 answer[i]에 index를 넣어주고, answer를 반환해주면서 코드는 끝이 납니다.

 

풀이 설명

이번 문제에서 원하는 것은 주어진 글자 s에서 같은 글자가 앞에 존재한다면, 그 중 가장 가까운 글자가 얼마나 앞에 있는지를 answer에 수의 배열로 나타내는 것입니다. 이때, 앞에 같은 글자가 없다면 -1로 표기합니다. 첫번째 for문은 s를 돌리는 for문입니다. s의 각 문자를 하나씩 판단하는 용도이기 때문에 다음for문으로 넘어가기 전 index를 -1로 초기화 해주는 과정이 필요합니다. 두번째 for문은 첫번째 for문으로 찾은 문자의 앞에 배치된 문자들을 검색하는 용도입니다. 이 안에서 if문에 걸리게 된다면, 같은 글자이고, 같은 글자라면 얼마나 앞에 있는지를 판단해야 하기 때문에 i번째 문자에서 j만큼 뒤로 이동한 i - j를 index에 넣어주게 됩니다. 그렇게 만들어진 index값을 answer배열에 순서대로 넣고 answer를 반환합니다.

 

<NEXT>

오늘은 "가장 가까운 같은 글자" 문제를 풀어보았습니다. 다음에는 "푸트 파이트 대회" 문제를 다뤄보도록 하겠습니다. 감사합니다.