본문 바로가기

Algorithm40

[백준] 14501번 퇴사 (Java) 백준 14501번 퇴사 : https://www.acmicpc.net/problem/14501 14501번: 퇴사 첫째 줄에 백준이가 얻을 수 있는 최대 이익을 출력한다. www.acmicpc.net 보자마자 DP 문제라고 느낌이 왔지만, dfs로 더 쉽게 풀 수 있을 듯 해서 dfs로 풀게 되었다. 삼성 SW 역량테스트 기출 문제라고 해서 풀어봤는데, 생각보다 너무 쉬워서 깜짝 놀랬다. 총 걸린 시간 : 20분 난이도 : ★☆☆☆☆ 코드 import java.io.BufferedReader; import java.io.InputStreamReader; import java.util.StringTokenizer; public class Main { private static int n, answer = .. 2020. 2. 25.
[SW Expert] [모의 SW 역량테스트] 2447번 차량 정비소 SW Expert [모의 SW 역량테스트] 2447번 차량 정비소 : https://swexpertacademy.com/main/code/problem/problemDetail.do?contestProbId=AV6c6bgaIuoDFAXy 역대급 요구사항이 많은 문제였다... 요구사항이 많다 보니 정리하는 것이 쉽지 않았다. 초기에 t = 0으로 선언한 뒤, while문 안에서 t를 1씩 증가시키며 시간의 흐름을 표현한다. 고객의 도착시간과 t가 일치한다면 reception Queue에 추가한다. 이는 고객이 방문하여 접수 창구 전에 기다리는 것을 나타낸다. 접수 창구와 정비 창구는 Desk라는 클래스를 선언하여 상태와 시간 등의 변수를 조작했다. Desk 클래스에는 clear, next, in 함수가 포.. 2020. 2. 24.
[SW Expert] [모의 SW 역량테스트] 2115번 벌꿀 채취 (Java) SW Expert [모의 SW 역량테스트] 2115번 벌꿀 채취 : https://swexpertacademy.com/main/code/problem/problemDetail.do?contestProbId=AV5V4A46AdIDFAWu 입력으로 각 벌통에 있는 꿀의 양이 주어졌을 때, 벌꿀을 채취하여 최대한 많은 수익을 얻어야 하는 문제이다. 입력으로 주어진 n의 값이 크지 않기 때문에 for문으로 모든 경우의 수를 전부 체크해주었다. 우선 벌통의 가장 앞의 index를 기준으로 노란색 벌통과 주황색을 선택해준다. solution 함수에서 4중 for문을 사용해서 두 벌통의 위치를 선택해주었다. 벌통의 위치가 고정이 되면, 이제 각 벌통에서 어느 값을 더해줄지를 판단한다. check 함수에서 각 벌통에서.. 2020. 2. 24.
[SW Expert] [모의 SW 역량테스트] 1952번 수영장 (Java) SW Expert [모의 SW 역량테스트] 1952번 수영장 : https://swexpertacademy.com/main/code/problem/problemDetail.do?contestProbId=AV5PpFQaAQMDFAUq 나는 이 문제를 dfs로 풀었지만, 풀이 후 다른 사람의 코드를 보니 DP로 푼 경우가 많았다. DP로는 각 단계마다 비용의 최솟값을 구하는 방식으로 푸는 듯 하다. 입력을 받을 때 1일치로 결제를 하는 것과 한 달을 결제하는 것 중에 작은 값을 배열에 저장한다. 그 뒤 dfs로 각각의 달에 어떤 방식으로 결제를 할지 선택한다. 결제 방식을 선택했다면 이용권 가격을 곱해서 총 비용을 계산해주면 된다. 총 걸린 시간 : 30분 난이도 : ★★☆☆☆ 코드 import java.i.. 2020. 2. 24.
[SW Expert] [SW Test 샘플문제] 1767번 프로세서 연결하기 (Java) SW Expert [SW Test 샘플문제] 1767번 프로세서 연결하기 : https://swexpertacademy.com/main/code/problem/problemDetail.do?contestProbId=AV4suNtaXFEDFAUf 상시 SW 역량테스트를 신청하기 전에 샘플문제로 풀어볼 수 있는 '프로세서 연결하기'이다. 최대한 많은 코어를 연결했을 때, 전선의 길이를 최소로 하는 값을 구하면 된다. bfs로 할지, dfs로 할지 고민을 하다가 bfs로 하면 배열 복사에 시간과 메모리 소모가 너무 많을 듯 하여 dfs로 풀이하게 되었다. 입력을 받을 때 코어의 위치들을 ArrayList에 저장한다. 그 뒤 코어의 위치에서 상하좌우로 연결이 가능한지 체크를 한다. (isConnect 함수) 연.. 2020. 2. 23.
[백준] 1022번 소용돌이 예쁘게 출력하기 (Java) 백준 1022번 소용돌이 예쁘게 출력하기 : https://www.acmicpc.net/problem/1022 1022번: 소용돌이 예쁘게 출력하기 첫째 줄에 r1, c1, r2, c2가 주어진다. 모두 절댓값이 5000보다 작거나 같은 정수이고, r2-r1은 0보다 크거나 같고, 49보다 작거나 같으며, c2-c1은 0보다 크거나 같고, 4보다 작거나 같다. www.acmicpc.net 이 문제의 포인트는 배열 선언을 어떻게 하느냐이다. r1, r2, c1, c2는 절댓값이 5000 이하이므로 사이즈가 10000짜리인 2차원 배열을 선언하면 모든 값을 담을 수 있다. 하지만 이런 식으로 코드를 짜면 무조건 메모리 초과가 뜨게 된다. 따라서 배열 선언을 상황에 맞게 유동적으로 해야한다. 문제 조건 중에 .. 2020. 2. 21.