일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 비트마스크
- 두원사이의정수쌍
- solved.ac골드
- 최소스패닝트리
- Lv2
- 2023카카오블라인드코테
- solved.ac플래티넘
- 정렬
- [pccp 기출문제]
- 백준알고리즘
- 우박수열정적분
- 지도 여러개
- 프로그래머스
- DP
- JS스터디
- React.StrictMode
- 백준 알고리즘
- c++
- 5강클로저
- 타겟넘버
- div2개
- Lv3
- 이중지도
- JS
- pccp기출문제
- 코어자바스크립트
- 스택
- 과제진행하기
- 알고리즘문제풀이
- 알고리즘 문제풀이
- Today
- Total
목록알고리즘 (101)
호지
펄스 수열은 두 종류가 있다 [-1, 1, -1...] , [1, -1, 1...] sequence가 주어지면 -1로 시작하는 펄스 수열과 곱해진 s1배열, 1로 시작하는 펄스 수열과 곱해진 s2배열 두가지로 나누어 생각했다. 가장 쉽게 생각할 수 있는 풀이방법은 DFS로 모든 경우의 수를 탐색하는 방법이었다. (하지만 이 방법은 시간 초과이다.) 다음으로 생각해본 방법은 DP이다. 모든 경우의 수를 탐색하면 이미 더했던 부분수열을 다시 더하고 하는 중복과정이 계속 발생한다. 또한 부분수열은 연속해서 이어지는 일렬의 과정이므로 for문 한번으로 해결할 수 있을 것 같았다. 과정은 s1과 s2를 나누어서 계산을 했다. cnt1과 cnt2는 dp배열로, i번째 위치의 의미는 해당 위치에서 나올 수 있는 부분..
BFS를 이용한 문제풀이입니다. 주어진 board에서 robot의 위치를 먼저 구합니다. 로봇은 상하좌우 방향으로 움직일 수 있고, 한 방향으로 움직이다가 장애물 D를 만나거나 board에 끝에 도달할때까지 움직입니다. 로봇이 움직일 수 있는 위치는 list큐에 넣습니다. 움직일 수 있는 위치 여부는 상하좌우(moves배열) 방향을 다 확인하고 한번 방문한 위치는 board를 C로 표기하여 중복 방문을 막습니다. list 큐가 empty면 G에 도달하지 못한 것이므로 -1을 반환하고, 중간에 G에 도달하면 해당위치의 count를 반환합니다. #include #include #include using namespace std; int solution(vector board) { int answer = -1..
역시 알고리즘은 끝이없다 두 선분이 만나는지 여부는 CCW알고리즘을 통해 구할 수 있다 CCW알고리즘은 3점의 방향성을 나타내고 시계방향일때는 -1, 직선일때는 0, 반시계방향일때는 1을 반환한다. 이 방향성을 응용하여 선분이 만나는지 확인할 수 있는데, 선분1 a(x1, y1), b(x2, y2) 선분2 c(x3, y3), d(x4, y4) 이 주어졌을 때 선분ab와 점 c, 선분 ab와 점 d의 ccw값이 둘 다 -1이거나 둘 다 1이면 선분 ab와 선분 cd는 만나지 않는다. 위를 이용해 ccw를 값을 이용해 선분ab, 선분 cd에 대해 교점이 있는지 확인하는 check 함수를 구현했다. 각 점에 대한 ccw값인 abc, abd, cda, cdb를 구하고, if(abc*abd ==0 && cda*c..