코테/프로그래머스
[프로그래머스/Lv. 1] 푸드 파이트 대회
imname1am
2023. 3. 15. 00:00
반응형
🔺 문제
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
🔺 코드
[JAVA] 프로그래머스 푸드파이트대회
LV.1 푸드파이트대회 📚
velog.io
import java.util.*;
class Solution {
public String solution(int[] food) {
StringBuilder sb = new StringBuilder();
for(int i=1 ; i < food.length ; i++) {
for(int j=0 ; j < (food[i] / 2) ; j++) {
sb.append(i);
}
}
String answer = sb.toString() + "0" + sb.reverse().toString();
return answer;
}
}
✅ StringBuilder 이용
쉬운 문제인데구현을 제대로 못해서 ArrayIndexOutOfBoundsException 뜨고 이래서 다른 분 코드를 보고 작성했다.
복습을 해야한다..
🔺 다른 풀이들
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
풀이1)
class Solution {
public String solution(int[] food) {
String answer = "0";
for (int i = food.length - 1; i > 0; i--) {
for (int j = 0; j < food[i] / 2; j++) {
answer = i + answer + i;
}
}
return answer;
}
}
너무 깔끔해서 눈물이 난다...ㅋㅋㅋㅋㅋ
풀이2)
class Solution {
public String solution(int[] food) {
StringBuilder sb = new StringBuilder();
for (int i = 1; i < food.length; i++) {
sb.append(Integer.toString(i).repeat(food[i] / 2));
}
return sb.toString() + "0" + sb.reverse().toString();
}
}
StringBuilder의 repeat 메소드를 사용한... 멋진 코드
StringBuilder를 잘 사용해봐야겠다...
반응형