inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

5-F

5-f 질문입니다

67

ililil

작성한 질문수 16

0

우선순위큐 크기가 가방 총 크기보다 클 때만 큐에서 빼는 로직을 작성했는데 왜 틀렸는지 궁금합니다

#include<bits/stdc++.h>
using namespace std; 
typedef long long ll;
priority_queue<ll> pq;
ll n,k,ret;
int main(){
    cin>>n>>k;
    pair<ll,ll> v[n]; //jewelry
    ll bag[k];

    for (int i=0;i<n;i++){
        cin>>v[i].first>>v[i].second;
    }
    for (int i=0;i<k;i++){
        cin>>bag[i];
    }
    int idx=0; //bag index

    sort(v,v+n);
    sort(bag,bag+k);
   
    int idx2=0;
    while (idx2<n){
        while (idx<k && idx2<n){
            if (bag[idx]<v[idx2].first) idx++;
            else{
                if (pq.size()==k){
                    if (v[idx2].second>pq.top()){
                        pq.pop();
                        pq.push(v[idx2].second);
                    }
                }else if (pq.size()<k) pq.push(v[idx2].second);
            }
            
            idx2++;
        }
    }
    while (pq.size()){
        ret+=pq.top(); pq.pop();
    }
   cout<<ret;

c++ 코딩-테스트

답변 2

0

큰돌

안녕하세요 ㅎㅎ

반례입니다.

4 3

2 3

2 1

3 5

3 6

3 3 3

 

답 : 14

수강생님 : 10

 

감사합니다.

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. ililil님.

질문하신 내용에 대해 설명드리겠습니다. 우선순위 큐를 사용할 때 가방의 총 크기를 확인하는 로직으로 접근하셨는데, 이 과정에서의 문제점을 아래에 설명드리겠습니다.

문제점 분석

  1. 가방과 보석 매칭:

    • bagv (보석)의 정렬 순서와 비교 로직을 보면, 현재 idx로 가방의 크기를 확인하고 idx2로 보석의 무게를 탐색합니다.
    • bag[idx] < v[idx2].first 이 조건을 통해 가방이 해당 보석을 담을 수 있는지를 확인하지만, 가방의 크기보다 보석의 무게가 큰 경우를 처리하지 않습니다.
  2. 우선순위 큐 조건:

    • 기존의 코드는 pq의 사이즈가 k보다 작을 때는 v[idx2].second (보석의 가치)를 pq에 추가합니다. 하지만, pq의 사이즈가 이미 k와 같을 때는 v[idx2].secondpq의 최솟값보다 큰 경우에만 최솟값을 업데이트합니다.
    • 이 로직은 어느 정도 올바르게 작동할 수 있으나, 전체 보석을 고려한 최적의 조합을 담기 위해서는 반복문 내부에서 최대한 많은 가치를 큐에 넣고 나중에 필요하지 않은 작은 가치를 빼는 방식으로의 접근이 필수적입니다.

대안 제안

  • 정렬된 보석과 가방을 효율적으로 이용:

    • 보석과 가방을 정렬한 후에, 가능한 무게 내에서 가치가 높은 보석을 최대한 가치가 높은 순으로 큐에 넣어야 합니다.
    • 가방 안에 담을 수 있는 보석을 큐에 추가하며, 이후 가방에 남은 공간이 있거나 가방이 채울 수 있는 가치보다 가치가 덜한 보석이 있다면 이를 교체하되 큰 가치로 업데이트합니다.
  • 우선순위큐에 대한 추가 논리 적용:

    • 큐의 크기가 k를 넘는 경우에 대한 명확한 처리보다는, 각 가방 단위로 최대 가치를 산정하고 이를 계속해서 업데이트하여 최종 가치를 산출하는 방식으로 로직을 보완해야 합니다.

아래 유사한 질문 링크에서 추가 설명을 확인할 수 있으니 보시길 추천드립니다:

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.

0

38

2

2주차 개념#12 트리 순회

0

21

2

백준사이트가 종료된다고 합니다.

0

261

2

백준 서비스 종료

9

824

1

sk 하이닉스 코테 대비

0

364

2

3-G 최댓값 질문

0

50

1

모듈러 연산 값이 10이 아닌 경우도 있지 않나요?

0

82

2

3-I 코드 질문드립니다.

0

62

2

3-N 질문 있습니다.

0

66

2

학습방법

0

101

2

4-H 질문 있습니다 (코드 리뷰)

0

66

2

코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.

0

167

2

2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.

0

69

2

2주차 개념 #4-2. 인접행렬 질문있습니다.

0

64

2

1-A 문제풀이 후 궁금한 점이 생겨서 질문드립니다.

0

50

2

조합 재귀 풀이 확인 해주시면 감사하겠습니다.

0

67

2

함수별 시간복잡도

0

72

2

3-h 질문입니다.

0

49

1

안녕하세요 선생님. 시간 복잡도 4번 질문있습니다.

0

52

2

1-I 문제 질문 드립니다.

0

76

2

2-P 질문입니다.

0

56

1

mac에서 시작하기 관련

0

90

2

5-Q 질문

0

63

2

풀이 코드 질문

0

64

2