알고리즘/프로그래머스
[프로그래머스] 잘라서 배열로 저장하기
CooNiHong
2022. 12. 8. 18:45
문제 링크
https://school.programmers.co.kr/learn/courses/30/lessons/120913
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
문제 설명
문자열 my_str과 n이 매개변수로 주어질 때, my_str을 길이 n씩 잘라서 저장한 배열을 return하도록 solution 함수를 완성해주세요.
제한사항
- 1 ≤ my_str의 길이 ≤ 100
- 1 ≤ n ≤ my_str의 길이
- my_str은 알파벳 소문자, 대문자, 숫자로 이루어져 있습니다.
입출력 예
my_str | n | result |
"abc1Addfggg4556b" | 6 | ["abc1Ad", "dfggg4", "556b"] |
"abcdef123" | 3 | ["abc", "def", "123"] |
입출력 예 설명
입출력 예 #1
- "abc1Addfggg4556b" 를 길이 6씩 잘라 배열에 저장한 ["abc1Ad", "dfggg4", "556b"]를 return해야 합니다.
입출력 예 #2
- "abcdef123" 를 길이 3씩 잘라 배열에 저장한 ["abc", "def", "123"]를 return해야 합니다.
유의사항
- 입출력 예 #1의 경우 "abc1Addfggg4556b"를 길이 6씩 자르면 "abc1Ad", "dfggg4" 두개와 마지막 "556b"가 남습니다. 이런 경우 남은 문자열을 그대로 배열에 저장합니다.
나의 풀이
Java
class Solution {
public String[] solution(String my_str, int n) {
int length = my_str.length()%n == 0 ? my_str.length()/n : my_str.length()/n + 1;
String[] strArr = new String[length];
int stratIndex = 0;
int endIndex = n;
for(int i = 0; i < strArr.length; i++) {
strArr[i] = my_str.substring(stratIndex, endIndex);
stratIndex += n;
endIndex = (endIndex + n) > my_str.length() ? my_str.length() : endIndex + n;
}
return strArr;
}
}
// 방법2
class Solution {
public String[] solution(String my_str, int n) {
String[] answer = my_str.split("(?<=\\G.{" + n + "})");
return answer;
}
}
방법2의 정규식은 검색해서 찾은 방법이지만 아직도 정확히 이해가 안됩니다. 아시는분 댓글로 알려주세요 ㅠㅠ
JavaScript
function solution(my_str, n) {
return my_str.match(new RegExp(`.{1,${n}}`, "g"));
}
1
728x90