티스토리 뷰
문제
영어 별로 안 어려우니까 읽자.
이 문제를 풀 때는 multiset자료구조를 이용하였는데 다음 두가지 이유 때문이다.
1. 매번 싸움마다 원소의 값이 가장 큰 놈을 알아야 한다. (& 그 놈만 알면 된다.)
2. 중복 원소를 허용해야 한다.
set은 1에 맞지만 2가 안 되기 때문에 중복 원소 허용의 multiset을 썼다.
주의할 점은 multiset의 erase함수를 value기반으로 사용하면 해당 value를 가진 모든 원소가 지워져버린다. 따라서 key를 기반으로 이 함수를 사용해야 의도한 결과를 낼 수 있다. (의도: 원소 하나만 삭제)
코드는 다음과 같다.
#include<iostream>
#include<set>
using namespace std;
int main() {
int N, SG, SB,B,temp;
cin >> N;
while (N--) {
multiset<int> Green;
multiset<int>::iterator gsoldier = Green.begin();
multiset<int> Blue;
multiset<int>::iterator bsoldier = Blue.begin();
cin >> B >> SG >> SB;
for (int i = 0; i < SG; i++) { //Green lemming input part
cin >> temp;
Green.insert(temp);
}
for (int i = 0; i < SB; i++) { //Blue lemming input part
cin >> temp;
Blue.insert(temp);
} //smallest element lies at begin, largest element lies at end in set
while (1) { //Deadly War starts
//ready for buffer
int* blue_buffer = new int[B];
int bbuf = 0;
int* green_buffer = new int[B];
int gbuf = 0;
if (Green.size() == 0 || Blue.size() == 0) break; //terminal condition of battle
for (int i = 0; i < B; i++) { //fighting part
if (Green.size() == 0 || Blue.size() == 0) break;
gsoldier = --Green.end();
bsoldier = --Blue.end();
if (*gsoldier > * bsoldier) { //green soldier-> survives at lower power, blue soldier->erase
temp = *gsoldier - *bsoldier;
Blue.erase(bsoldier);
Green.erase(gsoldier);
green_buffer[gbuf++] = temp;
}
else if (*gsoldier < *bsoldier) { //blue soldier ->survives at lower power, green soldier->erase
temp = *bsoldier - *gsoldier;
Blue.erase(bsoldier);
Green.erase(gsoldier);
blue_buffer[bbuf++] = temp;
// const_cast<int&>(*bsoldier) = *bsoldier - *gsoldier; 이거 되나 확인
}
else {
Green.erase(gsoldier);
Blue.erase(bsoldier);
}
}
for (int i = 0; i < bbuf; i++) {
Blue.insert(blue_buffer[i]);
}
for (int i = 0; i < gbuf; i++) {
Green.insert(green_buffer[i]);
}
delete[] blue_buffer;
delete[] green_buffer;
}
if (Green.size() == 0&&Blue.size() == 0) {
cout << "green and blue died" << endl;
}
else if (Green.size() != 0) {
cout << "green wins" << endl;
for (gsoldier = --Green.end(); gsoldier != Green.begin();gsoldier--) {
cout << *gsoldier << endl;
}
cout << *Green.begin() << endl;
}
else {
cout << "blue wins" << endl;
for (bsoldier = --Blue.end(); bsoldier != Blue.begin(); bsoldier--) {
cout << *bsoldier << endl;
}
cout << *Blue.begin() << endl;
}
if(N!=0) cout << endl;
}
}
'기초 알고리즘 문제 풀이' 카테고리의 다른 글
25. UVa-11849 CD (0) | 2020.02.23 |
---|---|
24. Uva-11136 Hoax or what //overflow (0) | 2020.02.23 |
22. UVa-11572 Unique Snowflakes (0) | 2020.02.22 |
21. Uva-11286 Conformity (0) | 2020.02.22 |
20. UVa-1062 (0) | 2020.02.22 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- ML
- Logistic Regression
- NLP
- 신호 및 시스템
- 매트랩 함수
- RGB이미지
- 매트랩
- gradient descent
- 이산 신호
- CS
- 인덱스 이미지
- CNN
- 이미지
- 영상처리
- 영상구조
- 머신 러닝
- 순환 신경망
- 자연어 처리
- 이미지처리
- 연속 신호
- 딥러닝
- Neural Network
- 밑바닥부터 시작하는 딥러닝
- 컴퓨터 과학
- 신경망
- Andrew ng
- 사진구조
- rnn
- 컴퓨터과학
- 머신러닝
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
글 보관함