Coding test/Programmers

[프로그래머스] 0단계_문자열 겹쳐쓰기 (Java)

dbswndud 2025. 5. 9. 14:36


문제 링크

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

 

프로그래머스

SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프

programmers.co.kr

 


문제 설명

문자열 my_string, overwrite_string과 정수 s가 주어집니다. 문자열 my_string의 인덱스 s부터 overwrite_string의 길이만큼을 문자열 overwrite_string으로 바꾼 문자열을 return 하는 solution 함수를 작성해 주세요.

 

작성한 코드

class Solution {
    public String solution(String my_string, String overwrite_string, int s) {
        String answer = "";
        
        for (int i = 0; i < my_string.length(); i++) {
            if (i >= s && i <= overwrite_string.length() + s - 1) {
                answer += overwrite_string.charAt(i - s);
            } else {
                answer += my_string.charAt(i);
            }
        }
        
        return answer;
    }
}

 

풀이

  • 문자열 길이만큼 for문을 반복합니다.
    • 만약 i가 정수 s보다 크고, 덮어쓸 문자열 길이 + s(덮어쓰기를 시작할 인덱스) - 1보다 작거나 같다면, 덮어쓸 문자를 answer에 더합니다.
      (위치 확인을 위한 계산)
    • 아니면 기존 문자열(덮어씌워지는)을 answer에 더합니다.

 

실행 결과