문제 |
11866번: 요세푸스 문제 0 (acmicpc.net)
11866번: 요세푸스 문제 0
첫째 줄에 N과 K가 빈 칸을 사이에 두고 순서대로 주어진다. (1 ≤ K ≤ N ≤ 1,000)
www.acmicpc.net
코드 (std::queue) |
#include <iostream>
#include <queue>
using namespace std;
int main() {
ios_base::sync_with_stdio(false);
cin.tie(nullptr);
queue<int> q;
int n, k;
cin >> n >> k;
for (int i = 1; i <= n; i++) {
q.emplace(i);
}
cout << '<';
while (--n) {
for (int i = 0; i < k - 1; i++) {
q.emplace(q.front());
q.pop();
}
cout << q.front() << ", ";
q.pop();
}
cout << q.front() << '>';
return 0;
}
설명 |
처리가 끝난 사람은 맨 끝에 추가로 넣고 pop한다.
Linked List나 배열 2개로 구현할 수도 있다.
'PS > BOJ' 카테고리의 다른 글
[C++] BOJ (백준) 18111 : 마인크래프트 (0) | 2023.03.06 |
---|---|
[C++] BOJ (백준) 15829 : Hashing (0) | 2023.03.05 |
[C++] BOJ (백준) 11651 : 좌표 정렬하기 2 (0) | 2023.03.05 |
[C++] BOJ (백준) 11650 : 좌표 정렬하기 (0) | 2023.03.05 |
[C++] BOJ (백준) 11050 : 이항 계수 1 (0) | 2023.03.05 |