Algorithm/Programmers 입문
[프로그래머스 코딩기초 트레이닝] 할 일 목록(JAVA)
JunFe
2023. 11. 28. 10:05
반응형
문제 설명
늘 해야 할 일이 담긴 문자열 배열 todo_list와 각각의 일을 지금 마쳤는지를 나타내는 boolean 배열 finished가 매개변수로 주어질 때, todo_list에서 아직 마치지 못한 일들을 순서대로 담은 문자열 배열을 return 하는 solution 함수를 작성해 주세요.
제한사항
1 ≤ todo_list의 길이 1 ≤ 100
2 ≤ todo_list의 원소의 길이 ≤ 20
- todo_list의 원소는 영소문자로만 이루어져 있습니다.
- todo_list의 원소는 모두 서로 다릅니다.
finished[i]는 true 또는 false이고 true는 todo_list[i]를 마쳤음을, false는 아직 마치지 못했음을 나타냅니다.
아직 마치지 못한 일이 적어도 하나 있습니다.
입출력 예
to_do_list | finished | result |
["problemsolving", "practiceguitar", "swim", "studygraph"] | [true, false, true, false] | ["practiceguitar", "studygraph"] |
입출력 예 설명
입출력 예 #1
예제 1번의 todo_list 중에서 "problemsolving"과 "swim"은 마쳤고, "practiceguitar"와 "studygraph"는 아직 마치지 못했으므로 todo_list에서 나온 순서대로 담은 문자열 배열 ["practiceguitar", "studygraph"]를 return 합니다.
풀이
-> arrayList를 선언해서 반복문을 통해 finished가 false인 것만 담은후 다시 answer에 반복문을 통해 담으면 간단하게 해결!
코드
import java.util.*;
class Solution {
public String[] solution(String[] todo_list, boolean[] finished) {
String[] answer = {};
ArrayList<String> temp = new ArrayList<>();
for(int i=0;i<todo_list.length;i++){
if(finished[i]==false){
temp.add(todo_list[i]);
}
}
answer = new String[temp.size()];
for(int i=0;i<temp.size();i++){
answer[i]=temp.get(i);
}
return answer;
}
}
반응형