1021번

2023. 2. 15. 16:39·CS 이론/알고리즘
728x90

https://www.acmicpc.net/problem/1021

 

1021번: 회전하는 큐

첫째 줄에 큐의 크기 N과 뽑아내려고 하는 수의 개수 M이 주어진다. N은 50보다 작거나 같은 자연수이고, M은 N보다 작거나 같은 자연수이다. 둘째 줄에는 지민이가 뽑아내려고 하는 수의 위치가

www.acmicpc.net

오늘 풀은 문제는 덱큐 문제인데, 좀 시간이 걸렸다.

이 문제에서 주의 할 것은 값을 빼는 것은 무조건 첫번째 인덱스라는 것이다.

나는 첫번째와 마지막에서 둘다 뺄 수 있는 줄 알고 로직을 짰다가 고생을 했다..

 

동작 방식은 간단하다.

주어진 뽑으려는 위치에 있는 값을 저장하고, 앞과 뒤중에 그 값에 더 가까운 곳에서 시작해서 뽑은 값을 옮기면 된다.

뽑으려는 값의 인덱스 위치를 찾고, 전체 큐의 크기에서 인덱스 값을 뺏을 때, 인덱스 값이 전체 큐의 크기에서 인덱스 값을 뺀 값보다 작다면

앞에서부터 값을 빼서 뒤로 옮기는 방식으로 찾으려는 값을 찾고, 찾는 과정에서 옮긴 횟수를 증가 시키면서 저장한다.

예를 들어 3 3 \n 2 1 3 이면 1 2 3 -> 2 3 1로 바꾸고 cnt+1, 2를 뽑고, 3 1 -> 1 3로 바꾸고 cnt+1하고 1뽑고, 3뽑는다.

그러면 횟수는 2이다.

 

정답 코드는 아래와 같다. 

package backjoon.b1021;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Deque;
import java.util.LinkedList;
import java.util.StringTokenizer;

public class b1021 {
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        StringTokenizer st = new StringTokenizer(br.readLine());
        int N = Integer.parseInt(st.nextToken());
        int M = Integer.parseInt(st.nextToken());

        LinkedList<Integer> deque = new LinkedList<>();
        int[] find = new int[M];
        
        st=new StringTokenizer(br.readLine());

        for(int i=0; i<M; i++){
            find[i]= Integer.parseInt(st.nextToken());
        }//찾아야할 인덱스값

        for(int i=1; i<=N; i++){
            deque.add(i);
        }//큐 채우기
        int count=0;
        for(int i=0; i<M; i++){
//            int target = deque.indexOf(find[i]);
//            int half;
//            if(deque.size()%2==0){
//                half = deque.size()/2-1;
//            }
//            else {
//                half = deque.size()/2;
//            }

//            if(target<=half){
            int comp = deque.indexOf(find[i]);

            if(deque.size()-comp>=comp){
                    while (true){
                        int tmp = deque.pollFirst();

                        if(tmp==find[i]){
                            break;
                        }
                        deque.addLast(tmp);
                        count++;
                    }
            }
            else {
                    while (true){
                        int tmp = deque.pollLast();

                        if(tmp==find[i]){
                            count++;
                            break;
                        }
                        deque.addFirst(tmp);
                        count++;
                    }
                }
            }

        System.out.println(count);

    }
}
728x90

'CS 이론 > 알고리즘' 카테고리의 다른 글

4963번  (0) 2023.02.18
10816번  (0) 2023.02.16
5639번  (0) 2023.02.14
1991번  (0) 2023.02.13
11725번  (1) 2023.02.12
'CS 이론/알고리즘' 카테고리의 다른 글
  • 4963번
  • 10816번
  • 5639번
  • 1991번
Bello's
Bello's
개발하는 벨로
  • Bello's
    벨로의 개발일지
    Bello's
  • 전체
    오늘
    어제
    • 분류 전체보기 (199) N
      • 노예 일지 (7)
        • 스타트업 노예일지 (3)
      • CS 이론 (81)
        • 학과 수업 (4)
        • 알고리즘 (64)
        • 시스템 프로그래밍 (3)
        • 데이터 통신 (1)
        • 운영체제 (2)
        • 데이터베이스 (1)
      • project (3)
      • 나는 감자다. (4)
      • Spring (27)
      • 모각코 (45)
        • 절개와지조(모각코) (7)
        • 어쩌다보니 박준태가 조장이조 (11)
        • 어쩌다보니 박준태가 또 조장이조 (12)
      • LikeLion🦁 (20)
      • 캘리포니아 감자 (4)
      • OpenSource Contribute (1)
      • 우아한테크벨로 (1) N
        • 프리코스 회고록 (6)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    모각코
    절개와지조
    프리코스
    어렵다
    백준
    자바
    타임리프
    회고록
    누적합
    나는 감자
    Spring
    오블완
    DFS
    뛰슈
    BFS
    JPA
    8기
    티스토리챌린지
    그래프 순회
    감자
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.5
Bello's
1021번
상단으로

티스토리툴바