728x90
문제
길이가 n이고, "수박수박수박수...."와 같은 패턴을 유지하는 문자열을 리턴하는 함수, solution을 완성하세요. 예를들어 n이 4이면 "수박수박"을 리턴하고 3이라면 "수박수"를 리턴하면 됩니다.
- 출력 예시 -
정답 코드
< 내 정답 코드 >
class Solution {
public String solution(int n) {
StringBuilder sb = new StringBuilder();
for (int i = 0; i < n / 2; i++) {
sb.append("수박");
}
if (n % 2 != 0) {
sb.append("수");
}
return new String(sb);
}
}
< 타인 답변 코드 >
class Solution {
public String solution(int n) {
StringBuilder answer = new StringBuilder();
for (int i = 1; i <= n; i++) {
answer.append(i % 2 != 0 ? "수" : "박");
}
return answer.toString();
}
}
이것을 주의하자!
- StringBuilder 을 사용했다. 그냥 String 문자열을 사용해도 되지만, 성능상의 이점을 활용했다.
- 나는 두 글자씩 접근하고, 마지막에 홀수면 "수" 를 붙이는 방향으로 했는데, 아예 홀수 인덱스면 "수"를, 짝수 인덱스면 "박"을 하나씩 붙이는 방법도 있다.
'코딩 테스트' 카테고리의 다른 글
[프로그래머스] (Lv.1) 문자열 다루기 기본 (0) | 2022.09.01 |
---|---|
[프로그래머스] (Lv.1) 서울에서 김서방 찾기 (0) | 2022.09.01 |
[프로그래머스] (Lv.1) 문자열을 정수로 바꾸기 * (0) | 2022.08.31 |
[프로그래머스] (Lv.1) 시저 암호 ** (0) | 2022.08.31 |
[프로그래머스] (Lv.1) 약수의 합 (0) | 2022.08.31 |