반응형
예제 입력 1
10 3
1 2 3
예제 출력 1
0
예제 입력 2
10 3
2 9 5
예제 출력 2
8
예제 입력 3
32 6
27 16 30 11 6 23
예제 출력 3
59
예제 입력 4
10 10
1 6 3 2 7 9 8 4 10 5
예제 출력 4
14
리뷰
큐 기본 형식의 변형 문제 (하단 링크 참조)
- 큐 오른쪽 회전 = 큐 기본 형식과 동일 (회전하는 만큼 더하기)
- front = (front + r_count) % len;
- 큐 왼쪽 회전 = 큐 기본 형식과 역순 (회전하는 만큼 빼기)
- front = (len + front - l_count) % len;
- 보안점:
- deque 활용
https://rnasterofmysea.tistory.com/42
#include <stdio.h>
#include <stdlib.h>
int main() {
int N, M;
scanf("%d %d", &N, &M);
// 원형 큐 초기화
int *cqueue = (int *)malloc(N * sizeof(int));
for (int i = 0; i < N; i++) {
cqueue[i] = i + 1; // 1부터 N까지 큐에 저장
}
int front = 0; // 큐의 시작 인덱스
int len = N; // 큐의 현재 크기
int result = 0;
for (int i = 0; i < M; i++) {
int m_input;
scanf("%d", &m_input);
// 목표 값의 위치 찾기
int l_count = 0;
int r_count = 0;
// 오른쪽 이동 횟수 계산
int flag = front;
while (cqueue[flag] != m_input) {
flag = (flag + 1) % len;
r_count++;
}
// 왼쪽 이동 횟수 계산
flag = front;
while (cqueue[flag] != m_input) {
flag = (len + flag - 1) % len;
l_count++;
}
// 이동 방향 결정 및 이동
if (r_count <= l_count) {
// 오른쪽 이동
front = (front + r_count) % len;
result += r_count;
} else {
// 왼쪽 이동
front = (len + front - l_count) % len;
result += l_count;
}
// 목표 값 제거 및 큐 크기 감소
for (int j = front; j < len - 1; j++) {
cqueue[j] = cqueue[(j + 1) % len];
}
len--;
if (front == len) {
front = 0; // 마지막 요소 제거 후, 큐 크기와 인덱스를 맞춤
}
}
printf("%d", result);
// 메모리 해제
free(cqueue);
return 0;
}
반응형
'Computer Science > 알고리즘 문제' 카테고리의 다른 글
C - [백준 2178] 미로탐색 (feat. BFS & 최단거리 탐색) (0) | 2024.12.26 |
---|---|
C - [백준 11724 재구현] 연결 요소의 개수 (feat. 리스트) (0) | 2024.12.24 |
C - [백준 11724] 연결 요소의 개수 (feat. 배열) (0) | 2024.12.23 |
C - [백준 1260] DFS와 BFS (0) | 2024.12.23 |
C - [Backjoon 10845] 큐 (큐 기본 형식) (0) | 2024.12.16 |