본문 바로가기

Algorithm

(390)
[프로그래머스] 미로 탈출 / BFS Level. 2 문제 1 x 1 크기의 칸들로 이루어진 직사각형 격자 형태의 미로에서 탈출하려고 합니다. 각 칸은 통로 또는 벽으로 구성되어 있으며, 벽으로 된 칸은 지나갈 수 없고 통로로 된 칸으로만 이동할 수 있습니다. 통로들 중 한 칸에는 미로를 빠져나가는 문이 있는데, 이 문은 레버를 당겨서만 열 수 있습니다.레버 또한 통로들 중 한 칸에 있습니다. 따라서, 출발 지점에서 먼저 레버가 있는 칸으로 이동하여 레버를 당긴 후 미로를 빠져나가는 문이 있는 칸으로 이동하면 됩니다. 이때 아직 레버를 당기지 않았더라도 출구가 있는 칸을 지나갈 수 있습니다. 미로에서 한 칸을 이동하는데 1초가 걸린다고 할 때, 최대한 빠르게 미로를 빠져나가는데 걸리는 시간을 구하려 합니다. 미로를 나타낸 문자열 배열 map..
[프로그래머스] 숫자 카드 나누기 Level. 2 문제 철수와 영희는 선생님으로부터 숫자가 하나씩 적힌 카드들을 절반씩 나눠서 가진 후, 다음 두 조건 중 하나를 만족하는 가장 큰 양의 정수 a의 값을 구하려고 합니다. - 철수가 가진 카드들에 적힌 모든 숫자를 나눌 수 있고 영희가 가진 카드들에 적힌 모든 숫자들 중 하나도 나눌 수 없는 양의 정수 a - 영희가 가진 카드들에 적힌 모든 숫자를 나눌 수 있고, 철수가 가진 카드들에 적힌 모든 숫자들 중 하나도 나눌 수 없는 양의 정수 a 예를 들어, 카드들에 10, 5, 20, 17이 적혀 있는 경우에 대해 생각해 봅시다. 만약, 철수가 [10, 17]이 적힌 카드를 갖고, 영희가 [5, 20]이 적힌 카드를 갖는다면 두 조건 중 하나를 만족하는 양의 정수 a는 존재하지 않습니다. 하지..
[프로그래머스(Java)] 홀수 vs 짝수 / iterate() Level. 0 문제 정수 리스트 num_list가 주어집니다. 가장 첫 번째 원소를 1번 원소라고 할 때, 홀수 번째 원소들의 합과 짝수 번째 원소들의 합 중 큰 값을 return 하도록 solution 함수를 완성해주세요. 두 값이 같을 경우 그 값을 return합니다. * 제한사항 - 5 ≤ num_list의 길이 ≤ 50 - -9 ≤ num_list의 원소 ≤ 9 풀이1 class Solution { public int solution(int[] num_list) { int num1=0, num2=0; for(int i=0; i i i+2).map(i->num_list[i]).sum(), IntStream.iterate(1, i-> i i+2).map(i->num_list[i]).sum()); }..
[프로그래머스(Java)] 가까운 1 찾기 / findFirst(), orElse() Level. 0 문제 정수 배열 arr가 주어집니다. 이때 arr의 원소는 1 또는 0입니다. 정수 idx가 주어졌을 때, idx보다 크면서 배열의 값이 1인 가장 작은 인덱스를 찾아서 반환하는 solution 함수를 완성해 주세요. 단, 만약 그러한 인덱스가 없다면 -1을 반환합니다. * 제한사항 - 3 ≤ arr의 길이 ≤ 100,000 - arr의 원소는 전부 1 또는 0입니다. 풀이1 class Solution { public int solution(int[] arr, int idx) { int answer = -1; for(int i=idx; iarr[i]==1).findFirst().orElse(-1); } } findFirst() 와 findAny() filter조건에 일치하는 요소 1개를..
[프로그래머스(Java)] 인덱스 바꾸기 / toCharArray(), String.valueOf() Level. 0 문제 문자열 my_string과 정수 num1, num2가 매개변수로 주어질 때, my_string에서 인덱스 num1과 인덱스 num2에 해당하는 문자를 바꾼 문자열을 return 하도록 solution 함수를 완성해보세요. * 제한사항 - 1 < my_string의 길이 < 100 - 0 ≤ num1, num2 < my_string의 길이 - my_string은 소문자로 이루어져 있습니다.num1 ≠ num2 풀이 class Solution { public String solution(String my_string, int num1, int num2) { char[] str = my_string.toCharArray(); str[num1] = my_string.charAt(num2);..
[프로그래머스(Java)] 문자열 정렬하기 (1) / replaceAll() Level. 0 문제 문자열 my_string이 매개변수로 주어질 때, my_string 안에 있는 숫자만 골라 오름차순 정렬한 리스트를 return 하도록 solution 함수를 작성해보세요. * 제한사항 - 1 ≤ my_string의 길이 ≤ 100 - my_string에는 숫자가 한 개 이상 포함되어 있습니다. - my_string은 영어 소문자 또는 0부터 9까지의 숫자로 이루어져 있습니다. - - - 풀이1 import java.util.List; import java.util.Arrays; import java.util.ArrayList; class Solution { public int[] solution(String my_string) { List list = new ArrayList();..
[프로그래머스] 방금그곡 / stringstream, getline Level. 2 문제 라디오를 자주 듣는 네오는 라디오에서 방금 나왔던 음악이 무슨 음악인지 궁금해질 때가 많다. 그럴 때 네오는 다음 포털의 '방금그곡' 서비스를 이용하곤 한다. 방금그곡에서는 TV, 라디오 등에서 나온 음악에 관해 제목 등의 정보를 제공하는 서비스이다. 네오는 자신이 기억한 멜로디를 가지고 방금그곡을 이용해 음악을 찾는다. 그런데 라디오 방송에서는 한 음악을 반복해서 재생할 때도 있어서 네오가 기억하고 있는 멜로디는 음악 끝부분과 처음 부분이 이어서 재생된 멜로디일 수도 있다. 반대로, 한 음악을 중간에 끊을 경우 원본 음악에는 네오가 기억한 멜로디가 들어있다 해도 그 곡이 네오가 들은 곡이 아닐 수도 있다. 그렇기 때문에 네오는 기억한 멜로디를 재생 시간과 제공된 악보를 직접 보면서..
[프로그래머스(Java)] 배열의 원소만큼 추가하기 / flatMap. Collections.nCopies() Level. 0 문제 아무 원소도 들어있지 않은 빈 배열 X가 있습니다. 양의 정수 배열 arr가 매개변수로 주어질 때, arr의 앞에서부터 차례대로 원소를 보면서 원소가 a라면 X의 맨 뒤에 a를 a번 추가하는 일을 반복한 뒤의 배열 X를 return 하는 solution 함수를 작성해 주세요. * 제한사항 - 1 ≤ arr의 길이 ≤ 100 - 1 ≤ arr의 원소 ≤ 100 풀이 import java.util.List; import java.util.ArrayList; import java.util.stream.*; class Solution { public int[] solution(int[] arr) { List list = new ArrayList(); for(int num : arr){ fo..