가장 가까운 같은 글자
오늘은 "가장 가까운 같은 글자" 문제를 풀어보도록 하겠습니다. 이제 프로그래머스 레벨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>
오늘은 "가장 가까운 같은 글자" 문제를 풀어보았습니다. 다음에는 "푸트 파이트 대회" 문제를 다뤄보도록 하겠습니다. 감사합니다.
'프로그래머스 코딩테스트 문제 > Level 1' 카테고리의 다른 글
[프로그래머스] - 콜라 문제(C#) (0) | 2023.08.31 |
---|---|
[프로그래머스] - 푸드 파이트 대회(C#) (0) | 2023.08.29 |
[프로그래머스] - 두 개 뽑아서 더하기(C#) (0) | 2023.08.27 |
[프로그래머스] - K번째 수(C#) (0) | 2023.08.26 |
[프로그래머스] - 문자열 내 마음대로 정렬하기(C#) (0) | 2023.08.24 |