본문 바로가기

알고리즘34

[백준] 1629번 곱셈 www.acmicpc.net/problem/1629 1629번: 곱셈 첫째 줄에 A, B, C가 빈 칸을 사이에 두고 순서대로 주어진다. A, B, C는 모두 2,147,483,647 이하의 자연수이다. www.acmicpc.net 구현 자체는 어렵지 않은데 방식을 모르면 쉽게 풀 수 없는 문제 같다. 여러 번 풀면서 방식을 익혀놓으면 다른 문제 풀 때 사고에 도움이 될 것 같다. 알고리즘 방식 #include #include #include #include #include #include #include #include #include using namespace std; long long pow(long long a, long long b, long long c) { if (b == 1) return.. 2021. 3. 17.
[백준] 9663번 N-Queen www.acmicpc.net/problem/9663 9663번: N-Queen N-Queen 문제는 크기가 N × N인 체스판 위에 퀸 N개를 서로 공격할 수 없게 놓는 문제이다. N이 주어졌을 때, 퀸을 놓는 방법의 수를 구하는 프로그램을 작성하시오. www.acmicpc.net 1793번 풀다가 세번째 풀어도 못푸는 나를 보고 자괴감에 빠져.... 오늘은 이걸로 포스팅하기로 했다. 내일 아침 자력으로 풀어내면 1793을 내일 포스팅하겠다. 변수 isused1, isused2, isused3 - x = i 일때, 각각 체스판의 가로영역, 대각선영역, 반대대각선영역의 사용 여부를 나타냄 cnt - 퀸의 개수 n - 입력 값 N 알고리즘 방식 백트래킹을 통해 구현했다. 간단히 설명하면 cur = x 좌표,.. 2021. 3. 16.
[백준] 1463번 1로 만들기 www.acmicpc.net/problem/1463 1463번: 1로 만들기 첫째 줄에 1보다 크거나 같고, 106보다 작거나 같은 정수 N이 주어진다. www.acmicpc.net BFS를 통해 구현했다. 처음에 1에서 n을 찾는 방식으로 구현했는데 n에서 1을 찾는 방식에 비해 메모리와 시간이 커서 고민을 많이했다. 결과론적으로 전자는 n 이상의 범위까지 탐색을 시도하지만 후자는 1로 수렴한다는 느낌인 것 같다. (곰곰히 생각해보면 곱하기와 나누기의 차이인 것 같다. 곱셈을 통한 BFS를 하면 q에 들어가는 데이터 하나하나 사이의 값들이 커져서 채워져 있는 board의 중복을 통한 소거의 빈도가 줄어 든다. 반대로 나눗셈을 통한 BFS는 q에 들어가는 데이터 하나하나 사이의 값들이 작아져 채워져 있는.. 2021. 3. 16.
[백준] 9466번 텀 프로젝트 www.acmicpc.net/problem/9466 9466번: 텀 프로젝트 이번 가을학기에 '문제 해결' 강의를 신청한 학생들은 텀 프로젝트를 수행해야 한다. 프로젝트 팀원 수에는 제한이 없다. 심지어 모든 학생들이 동일한 팀의 팀원인 경우와 같이 한 팀만 있을 www.acmicpc.net 풀이 방식이 어떻게 보면 꼼수일 수도 있는 것 같은데 이전과 비교하면 메모리와 시간을 굉장히 많이 단축해서 뿌듯해서 올려본다. 변수 배열 board - n개의 선택된 학생들의 번호가 저장 배열 vis - n명의 학생들에 대해 선택 여부 저장 변수 result - 결과값 (프로젝트 팀에 속하지 못한 학생들의 수) 큐 q - BFS에서 사이클을 확인하는 데 사용됨 알고리즘 방식 * 데이터를 입력받을 때 자기 자신을 가르.. 2021. 3. 13.
[백준] 4179번 불! www.acmicpc.net/problem/4179 4179번: 불! 입력의 첫째 줄에는 공백으로 구분된 두 정수 R과 C가 주어진다. 단, 1 ≤ R, C ≤ 1000 이다. R은 미로 행의 개수, C는 열의 개수이다. 다음 입력으로 R줄동안 각각의 미로 행이 주어진다. 각각의 문 www.acmicpc.net 생각해낸 방식이 마음에 들어서 포스팅해놓으려한다. 방식은 조금 복잡한데 옛날에 풀었던 것보다 시간이 1/4정도 줄었다. 큐를 하나만 이용해서 풀었다. 말로 어떻게 풀어야될지 잘 모르겠는데 시간에 따른 J와 F를 J1,J2,J3... 과 F1,F2,F3...로 표현하겠다. 1. 처음 큐에 F1F1J1과 같이 F를 앞에 J를 제일 뒤에 넣어준다. (불을 먼저 번지게 하고 사람이 움직이는게 더 간단하다.. 2021. 3. 13.
[백준] 1600 말이 되고픈 원숭이 www.acmicpc.net/problem/1600 1600번: 말이 되고픈 원숭이 첫째 줄에 정수 K가 주어진다. 둘째 줄에 격자판의 가로길이 W, 세로길이 H가 주어진다. 그 다음 H줄에 걸쳐 W개의 숫자가 주어지는데, 0은 아무것도 없는 평지, 1은 장애물을 뜻한다. 장애물이 있 www.acmicpc.net 아이디어는 어렵지 않은데 코드로 구현해내는 방식이 어려웠다. cur.first.first 와 cur.first.second 에 각각 원숭이의 x, y좌표를 cur.second.first 와 cur.second.second에 각각 말처럼 이동한 횟수, 총이동 횟수를 저장하였다. BFS과정을 통해 진행되며 도착점(오른쪽 하단)에 최초로 도착하게 될 때, cur.second.second + 1의 값을.. 2021. 3. 10.