inblog logo
|
silver
    알고리즘문제풀기

    [알고리즘문제풀기] 왼쪽 오른쪽

    silver's avatar
    silver
    Sep 30, 2025
    [알고리즘문제풀기] 왼쪽 오른쪽
    Contents
    문제내가 작성한 정답다른 사람들의 정답

    문제

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

    내가 작성한 정답

    import java.util.*; class Solution { public String[] solution(String[] str_list) { List<String> answer = new ArrayList<>(); for(int i=0; i<str_list.length;i++){ if(str_list[i].equals("l")) { for(int j=0; j<i; j++){ answer.add(str_list[j]); } break; } else if (str_list[i].equals("r")) { for(int j=i+1; j<str_list.length; j++){ answer.add(str_list[j]); } break; } } return answer.stream().toArray(String[]::new); } } class Solution { public String[] solution(String[] str_list) { for(int i=0; i<str_list.length;i++){ if(str_list[i].equals("l")) { return Arrays.copyOfRange(str_list,0,i); } else if (str_list[i].equals("r")) { return Arrays.copyOfRange(str_list,i+1,str_list.length); } } return new String[0]; } }

    다른 사람들의 정답

    import java.util.Arrays; import java.util.stream.IntStream; class Solution { public String[] solution(String[] str_list) { return IntStream.range(0, str_list.length) .boxed() .filter(i -> str_list[i].equals("l") || str_list[i].equals("r")) .findFirst() .map(i -> { if (str_list[i].equals("l")) { return Arrays.copyOfRange(str_list, 0, i); } return Arrays.copyOfRange(str_list, i + 1, str_list.length); }) .orElseGet(() -> new String[]{}); } }
    Share article

    silver

    RSS·Powered by Inblog