본문 바로가기

Algorithm283

[2018 카카오 기출] 프렌즈4블록(JAVA) programmers.co.kr/learn/courses/30/lessons/17679 시뮬레이션 문제입니다. m,n 제한이 작으므로 루프를 돌리면서 부숴지는 블록이 없을 때 까지 전부 탐색해주면 됩니다. 코드: github.com/cotchan/algorithm/blob/main/java/PROGRAMMERS/PG17679.java 2021. 5. 12.
[2020 카카오 기출] 경주로 건설(JAVA) programmers.co.kr/learn/courses/30/lessons/67259 DP 문제입니다. 저는 dp 상태를 아래와 같이 정의했습니다. dp[dir][y][x]: board[y][x]에 경주로를 놓았고 현재 진행중인 방향은 dir인 상태입니다. dir은 UP LEFT DOWN RIGHT 4가지 상태중 하나를 가지게 됩니다. 경주로를 놓기 위해 새로운 칸을 탐색할 때 총 3방향을 탐색할 수 있습니다. 1. 온 방향 그대로 진행 2. 온 방향과 90도를 이루는 방향 진행 그리고 그 때 마다 금액을 쌓아주면 됩니다. 단 제가 구하는 방식의 경우 코너 도로를 놓을 때 100원씩이 누락됩니다. 예를 들어, ㅣ ㄴ ㅡ 이렇게 3개의 도로를 놓는다고 할 때 총 700원이 들어야 하지만, 제가 구현한 방.. 2021. 5. 11.
[2020 카카오 기출] 수식 최대화(JAVA) programmers.co.kr/learn/courses/30/lessons/67257 시뮬레이션 문제입니다. 연산자가 최대 3개이므로 나타날 수 있는 우선순위 경우의 수는 6개입니다. 생길 수 있는 모든 우선순위 경우의 수로 연산을 한 뒤 최댓값을 구하면 됩니다. 코드: github.com/cotchan/algorithm/blob/main/java/PROGRAMMERS/PG67257.java 2021. 5. 10.
[2019 카카오 기출] 실패율(JAVA) programmers.co.kr/learn/courses/30/lessons/42889 스테이지의 갯수 제한이 작으므로 스테이지 크기만큼 배열을 선언해도 됩니다. N개의 스테이지에 대해 성공한 사람의 인원 수, 실패한 사람의 인원 수를 저장해놓는 방식으로 해결했습니다. 코드: github.com/cotchan/algorithm/blob/main/java/PROGRAMMERS/PG42889.java 2021. 5. 4.