728x90

Algorithm

    [프로그래머스] 2020 KAKAO BLIND RECRUITMENT 외벽 점검 (Java)

    프로그래머스 2020 KAKAO BLIND RECRUITMENT 외벽 점검 : https://programmers.co.kr/learn/courses/30/lessons/60062 코딩테스트 연습 - 외벽 점검 | 프로그래머스 레스토랑을 운영하고 있는 스카피는 레스토랑 내부가 너무 낡아 친구들과 함께 직접 리모델링 하기로 했습니다. 레스토랑이 있는 곳은 스노우타운으로 매우 추운 지역이어서 내부 공사를 하는 도중에 주기적으로 외벽의 상태를 점검해야 할 필요가 있습니다. 레스토랑의 구조는 완전히 동그란 모양이고 외벽의 총 둘레는 n미터이며, 외벽의 몇몇 지점은 추위가 심할 경우 손상될 수도 있는 취약한 지점들이 있습니다. 따라서 내부 공사 도중에도 외벽의 취약 지점들이 손상되지 않 programmers.co..

    [프로그래머스] 2020 KAKAO BLIND RECRUITMENT 기둥과 보 설치 (Java)

    문제 : https://programmers.co.kr/learn/courses/30/lessons/60061 코딩테스트 연습 - 기둥과 보 설치 | 프로그래머스 5 [[1,0,0,1],[1,1,1,1],[2,1,0,1],[2,2,1,1],[5,0,0,1],[5,1,0,1],[4,2,1,1],[3,2,1,1]] [[1,0,0],[1,1,1],[2,1,0],[2,2,1],[3,2,1],[4,2,1],[5,0,0],[5,1,0]] 5 [[0,0,0,1],[2,0,0,1],[4,0,0,1],[0,1,1,1],[1,1,1,1],[2,1,1,1],[3,1,1,1],[2,0,0,0],[1,1,1,0],[2,2,0,1]] [[ programmers.co.kr 2020 카카오 공채의 5번째 문제 기둥과 보 문제다. 예..

    [프로그래머스] 2020 KAKAO BLIND RECRUITMENT 가사 검색 (Java)

    프로그래머스 2020 KAKAO BLIND RECRUITMENT 가사 검색 : https://programmers.co.kr/learn/courses/30/lessons/60060 코딩테스트 연습 - 가사 검색 | 프로그래머스 programmers.co.kr 예전에 못 풀었다가 다시 한번 도전하게 된 2020 카카오 공채의 가사 검색이다. 트라이라는 자료구조를 처음 알게 된 문제다. 이 문제를 처음 접했을 때는 단순하게 정규표현식을 사용해서 문제를 풀어야겠다고 생각했다. 하지만 정규표현식으로 풀게 되면 선형 시간으로 비교를 해야 해서 정확성 테스트는 통과하지만 효율성 테스트를 통과하지 못한다. 따라서 도저히 답을 찾지 못해 구글링을 해보았고, 트라이라는 자료구조를 사용해야 된다는 것을 보게 되었다. 트라..

    [백준] 15684번 사다리 조작 (Java)

    백준 15684번 사다리 조작 : https://www.acmicpc.net/problem/15684 15684번: 사다리 조작 사다리 게임은 N개의 세로선과 M개의 가로선으로 이루어져 있다. 인접한 세로선 사이에는 가로선을 놓을 수 있는데, 각각의 세로선마다 가로선을 놓을 수 있는 위치의 개수는 H이고, 모든 세로선 www.acmicpc.net 개인적으로 많이 어려웠던 문제다. 처음에는 bfs로 시도해봤지만 배열을 복사하는 탓에 메모리, 시간 초과가 떠서 dfs로 풀게 되었다. 평소에 사용하던 dfs의 방식으로 풀이하여 통과하긴 했지만, 모든 경우의 수를 전부 확인하며 최소값을 찾는 방법이기 때문에 시간이 오래 걸렸다. 따라서 이 문제에서는 dfs를 약간 독특하게 변형하여 풀었다. 사다리의 수를 0, ..

    [백준] 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 = ..

    [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 함수가 포..

    [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 함수에서 각 벌통에서..

    [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..

728x90