본문 바로가기
Computer Science/알고리즘 문제

C - [백준 1021] 회전하는 큐

by rnasterofmysea 2024. 12. 19.
반응형

 

예제 입력 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

 

C - [Backjoon 10845] 큐 (큐 기본 형식)

출처:https://www.acmicpc.net/problem/10845 예제 입력 1 15push 1push 2frontbacksizeemptypoppoppopsizeemptypoppush 3emptyfront예제 출력 1 122012-101-103  리뷰큐 기본 형 구현이기 때문에 필수로 짚고 넘어가야하는 코드해

rnasterofmysea.tistory.com

 

#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;
}
반응형