4-A 19942
446
작성한 질문수 5
http://boj.kr/377650e87589448abf24b7196faba01b
안녕하세요 여러번 시도를 해봐도 어디서 틀린건지 잘 모르겠습니다..ㅜㅡㅜ
답변 1
0
안녕하세요 ㅎㅎ
이부분만 바꿔서 제출해보시면 맞게 나옵니다.
#include <bits/stdc++.h>
using namespace std;
const int INF = 987654321;
int n, mp, mf, ms, mv, rp, rf, rs, rv, rc, cost = INF;
int p[16], f[16], s[16], v[16], c[16];
map<int, vector<vector<int>>> temp;
vector<int> vec, ret;
int main(){
cin >> n >> mp >> mf >> ms >> mv;
for(int i = 1; i <= n; i++){
cin >> p[i] >> f[i] >> s[i] >> v[i] >> c[i];
}
for(int i = 0; i < (1 << n); i++){
vec.clear();
rp = 0; rf = 0; rs = 0; rv = 0; rc = 0;
for(int j = 0; j < n; j++){
if(i & (1 << j)){
vec.push_back(j + 1);
}
}
for(int k : vec){
rp += p[k];
rf += f[k];
rs += s[k];
rv += v[k];
rc += c[k];
}
if(rp < mp || rf < mf || rs < ms || rv < mv) continue;
if(rc < cost){
cost = rc;
ret.clear();
ret = vec;
temp[cost].push_back(vec);
continue;
}
if(rc == cost){
temp[cost].push_back(vec);
vec.clear();
}
}
if(cost == INF) cout << "-1" << '\n';
else{
sort(temp[cost].begin(), temp[cost].end());
cout << cost << '\n';
for(int i : temp[cost][0]) cout << i << " ";
}
return 0;
}
즉,
이부분이 틀린 건데요.
if(rc == cost){
int length = vec.size() < ret.size() ? vec.size() : ret.size();
for(int k = 0; k < length; k++){
if(vec[k] < ret[k]){
ret.clear();
ret = vec;
}
}
}이게 왜 틀렸을까요?
저도 이부분은 맞다고 생각하는데..
저도 이해가 안되서
한번 예제를 만들어서 해봤습니다.
#include <bits/stdc++.h>
using namespace std;
vector<vector<int>> ret;
int max_n = 9;
/*
vec < ret
1 2 3 4 5 6 7 8 9
1 2 3 4 5 8
vec < ret
1 2 3 4 5 6 7 8 9
1 2 3 4 5 6 8
*/
int cnt = 0;
void f(vector<int> vec, vector<int> ret){
int length = vec.size() < ret.size() ? vec.size() : ret.size();
for(int k = 0; k < length; k++){
if(vec[k] < ret[k]){
if(vec.size() == ret.size()){
if(++cnt == 1000) exit(0);
cout << "vec < ret \n";
for(int i : vec) cout << i << ' ';
cout << '\n';
for(int i : ret) cout << i << ' ';
cout << '\n';
}
return;
}
}
}
int main(){
vector<int> v;
for(int i = 1; i <= max_n; i++){
v.push_back(i);
}
do{
for(int j = 1; j <= max_n; j++){
vector<int> temp;
for(int i = 0; i < j; i++){
temp.push_back(v[i]);
}
sort(temp.begin(), temp.end());
ret.push_back(temp);
}
}while(next_permutation(v.begin(), v.end()));
for(int i = 0; i < ret.size(); i++){
for(int j = 0; j < i; j++){
f(ret[i], ret[j]);
}
}
return 0;
}자, 이걸 돌려보면요.
vec < ret
1 2 3 4 5 6 7 8 9
1 2 3 4 5 8
vec < ret
1 2 3 4 5 6 7 8 9
1 2 3 4 5 6 8
잘 나옵니다. 로직이 잘됩니다..
1 2 3 4 5 7 8 9
vec < ret
1 2 3 4 5 6 8 9
1 2 3 4 5 7 8 9
vec < ret
1 2 3 4 5 6 8 9
1 2 3 4 5 7 8 9
vec < ret
1 2 3 4 5 6 8 9
1 2 3 4 5 7 8 9
vec < ret
같은 사이즈인지 확인하는 로직을 넣어도 됩니다.
즉, 저부분이 틀린지는 확인을 했으나 왜 틀린지는 저도 잘 모르겠습니다. ㅠㅠ
많이 봤는데... 제 역량 부족이네요.. 일단 넘어가시고 저도 시간 남을 때 한번 더 보겠습니다.
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
살구클럽 아이디 없음 문제
0
8
0
1-O 코딩살구클럽 채점관련 질문
0
24
2
히든 테스트 케이스가 사라졌습니다
0
16
1
채점서버 혹시 다른 언어 지원도 가능하게 해주실 수 있나요
1
31
2
살구 클럽 채점 관련 문의(테스트 케이스)
0
29
2
1-H 문제 채점하기 오류
0
20
3
코딩살구클럽 2주차 2-L 문제 채점하기 오류
0
29
2
살구 클럽 채점 관련 문의
0
35
2
코딩 살구 클럽 실전 세션
0
29
2
코딩살구클럽 컴파일에러
0
64
2
5-B
0
46
2
4 - A
0
49
2
코딩살구클럽 입장이 안됩니다
0
108
2
4-F 경우의 수 질문입니다.
0
49
2
코딩살구클럽 가입이 안됩니다.
0
106
2
살구 클럽에 대한 질문있습ㄴ디ㅏ
0
73
1
교안 158페이지 문의드립니다
0
53
2
코딩살구클럽 관련 건의사항
0
148
1
코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다
0
54
1
진행 방법 질문드립니다!
0
98
2
2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.
0
65
2
2주차 개념#12 트리 순회
0
34
2
백준사이트가 종료된다고 합니다.
0
330
2
백준 서비스 종료
9
1000
1





