https://www.acmicpc.net/problem/12873
백준이는 BOJ 알고리즘 캠프 참가자 중 한 명에게 기념품을 주려고 한다. 하지만, 많은 참가자 중에서 어떤 사람을 뽑아서 기념품을 줘야하는지 고민이 되기 시작했다. 따라서, 백준이는 게임을 통해서 기념품을 받을 사람을 정하기로 결정했다.
게임이 시작하기 전에 모든 참가자 N명은 원을 이루어서 앉아있다. 다음, 1부터 N까지 번호가 적혀있는 티셔츠를 시계방향으로 입는다. 이 티셔츠는 게임에 사용되지 않으며, 게임을 쉽게 하기 위해서 입는 티셔츠이다.
게임은 단계로 이루어져 있으며, 첫 단계는 1단계이다. 각 단계가 시작될 때, 백준이는 어떤 참가자의 앞에 서있다. 그 다음, "하나"를 외친다. 그 다음, 시계 방향으로 다음 사람에게 이동하며 "둘"을 외친다. 이 과정은 t단계인 경우에 t3을 외칠 때 까지 진행한다. 예를 들어, 1단계에서는 1까지 외치며, 2단계에서는 8까지, 3단계에서는 27까지 외친다.
각 단계가 끝난 경우에, 백준이가 앞에 서 있는 사람은 게임에서 제외된다. (t단계인 경우에 t3을 외칠 때 앞에 있던 사람) 사람이 제거된 후에는 백준이는 시계 방향으로 다음 사람에게 이동한다. 1단계에서 백준이는 티셔츠 1번을 입고 있는 사람의 앞에 있다. 게임은 원에 한 명이 남을 때 까지 진행되며, 마지막 남은 사람이 기념품을 가져가게 된다.
참가자의 수 N이 주어졌을 때, 어떤 티셔츠를 입고 있는 사람이 기념품을 받는지 구하는 프로그램을 작성하시오.
첫째 줄에 BOJ 캠프 참가자의 수 N (1 ≤ N ≤ 5,000)이 주어진다.
첫째 줄에 기념품을 받는 사람이 입고 있는 티셔츠의 번호를 출력한다.
import java.util.LinkedList;
import java.util.Scanner;
public class pr12873 {
static int getDel(int i, int mod) {
int ans=i;
ans*=i;
ans%=mod;
ans*=i;
return ans%mod;
}
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
LinkedList<Integer> queue = new LinkedList<>();
int N = sc.nextInt();
for (int i = 1; i < N + 1; i++)
queue.add(i);
int bf=0;
for (int i = 1; i < N; i++) {
int delNum = (bf+getDel(i,queue.size())-1)%queue.size(); // 인덱스
if (delNum < 0)
delNum +=queue.size();
queue.remove(delNum);
for (int j = 0; j < delNum; j++) {
queue.add(queue.poll());
}
}
System.out.println(queue.poll());
}
}
도무지 런타임에러를 해결할 수 없어 이 풀이를 따라 풀었다 ,,
int delNum=(i*i*i)%queue.size()-1;
위의 식으로 풀려고 했는데 delNum이 음수일 경우에서 계속 런타임에러가 발생했다 ,,, 해결하면 다시 올리도록 하겠다 😭