일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- Firebase
- 앱출시
- bookmark
- 개발일지
- 알고리즘
- double colon
- Groovy lambda
- 안드로이드
- Android App 출시
- Android 앱 출시
- 이중콜론
- groovy double colon
- 그루비 람다
- sql 소수점제거
- android
- 프로그래머스 수박수박수박수박수박수
- 구글 플레이 스토어 출시
- 1인개발
- 예약 배포
- sql truncate
- mysql 소수점 함수
- 파이어베이스
- Firebase Crashlytics
- 북마크
- 예약 게시
- 게시 개요
- 코딩테스트
- 푸시메세지
- 프로그래머스
- 파이어베이스 크래시틱스
Archives
- Today
- Total
Moon_Dev_Blog :)
[프로그래머스] 수박수박수박수박수박수? / Java 본문
안녕하세요. 본 포스팅은 주관적으로 작성되며, 틀린 정보가 있을시에 따끔한 충고 부탁드리겠습니다. 감사합니다.
내용 :
문제 설명
길이가 n이고, 수박수박수박수....와 같은 패턴을 유지하는 문자열을 리턴하는 함수, solution을 완성하세요. 예를들어 n이 4이면 수박수박을 리턴하고 3이라면 수박수를 리턴하면 됩니다.
제한 조건
- n은 길이 10,000이하인 자연수입니다.
문제 풀이
class Solution {
public String solution(int n) {
String answer = "";
String word = "수박";
if(n <= 10000) {
for(int i=0; i < n; i++) {
answer += word;
}
if(n % 2 == 1) {
answer = answer.substring(0, n);
} else if(n % 2 == 0) {
int dev = answer.length() / 2;
answer = answer.substring(0, dev);
}
}
return answer;
}
}
10000개 이하일때 n의 비즈니스 로직을 태우며, 수박이라는 단어를 n의 길이만큼 더한 후 홀or짝 수의 로직에 따라 글자를 자르는 로직을 구성했다.
문제를 풀고보니 로직이 너무 복잡해 보였고, 리펙토링 과정에서 삼항연산자를 활용하여 코드를 간소화 시킬 수 있었다.
class Solution {
public String solution(int n) {
String answer = "";
if(n <= 10000) {
for(int i=0; i < n; i++) {
answer += (i % 2 == 0) ? "수" : "박";
}
}
return answer;
}
}
출처: 프로그래머스 코딩 테스트 연습, https://programmers.co.kr/learn/challenges
'IT > 알고리즘풀이' 카테고리의 다른 글
[프로그래머스] 문자열 여러 번 뒤집기 (5) | 2024.12.23 |
---|---|
[프로그래머스] 피자 나눠 먹기 (2) (0) | 2024.12.21 |
[프로그래머스] Day4 연산, 조건문 (0) | 2024.12.10 |
[프로그래머스] 서울에서 김서방 찾기 / Java (0) | 2021.03.01 |
Comments