본문 바로가기

Programmers

(188)
다리를 지나는 트럭 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 import java.util.*; class Solution { public int solution(int bridge_length, int weight, int[] truck_weights) { Queue queue = new LinkedList(); Queue time = new LinkedList(); int answer = 0, pos = 0; while (pos
멀쩡한 사각형 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 class Solution { public long solution(long w, long h) { long answer = w * h; long a = w, b = h; // 유클리드 호제법 while (b != 0) { long r = a % b; a = b; b = r; } answer -= w + h - a; return answer; } } Colored by Color Scripter cs 사각형이 색칠되는 규칙은 다음과 같다. 가로 w, 세로 h, 최대 공약수 a라고 했을 때, ( w / a + h / a - 1 ) * a 이다. 즉, w와 h의 비율로 가장 작은 사각형이 a개가 나오고 그 안에서 색칠이 된다. 색칠이 되는..
주식가격 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 class Solution { public int[] solution(int[] prices) { int len = prices.length; int[] answer = new int[len]; for (int i = 0; i
위장 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 import java.util.*; class Solution { public int solution(String[][] clothes) { int answer = 1; Map map = new HashMap(); // 옷 종류에 따른 갯수 저장 for (int i = 0; i
H-Index 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 import java.util.*; class Solution { public int solution(int[] citations) { int answer = 0; int len = citations.length; int i; Arrays.sort(citations); for (i = len - 1; i >= 0; i--) { if (len - i
카펫 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 32 33 34 35 import java.util.*; class Solution { public int[] solution(int brown, int yellow) { int[] answer = new int[2]; List list = new ArrayList(); // 약수 구하기 int n = brown + yellow; for (int i = 1; i
조이스틱 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 class Solution { public int solution(String name) { int answer = 0; int len = name.length(); int move = len - 1; // 일직선으로 갈 때의 움직임 횟수 for (int i = 0; i
프린터 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 32 33 34 35 36 37 import java.util.*; class Solution { public int solution(int[] priorities, int location) { int answer = 0; Queue queue = new LinkedList(); // 우선순위 큐 내림차순 정렬 PriorityQueue priQueue = new PriorityQueue(Collections.reverseOrder()); // 우선순위 목록 저장, queue 초기화 for (int i = 0; i n.priority) { queue.add(..