inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

5-A

5-A 질문있습니다

71

gimg6156

작성한 질문수 3

0

- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.

#include<iostream>
#include<deque>
#include<utility>
#include<algorithm>

using namespace std;


int n,p,d,ret=0,p1,d1,num;
deque<pair<int,int>> dp;

bool comp(const pair<int,int> &a, const pair<int,int>&b){
   return a.second<b.second;
}

int main(){
   ios_base::sync_with_stdio(false);
   cin.tie(NULL);
   cout.tie(NULL);
   cin>>n;
   for(int i=0; i<n;i++){
      cin>>p>>d;
      dp.push_back({p,d});
   }
   sort(dp.begin(),dp.end(),comp);

   num = dp.back().first;
   d1 = dp.back().second;
   dp.pop_back();
   for(auto a = dp.rbegin(); a != dp.rend(); a++){
      if(d1 == a->second){
         num = max(num,a->first);
      }
      else{
         ret += num;
         num = a->first;
         d1 = a->second;
      }
   }
   ret += num;
   cout<<ret;
   return 0;
}

 

저는 이런 방식으로 풀어보았는데 어떤 문제점이 있을까요?

c++ 코딩-테스트

답변 2

0

큰돌

안녕하세요 ㅎㅎ

다음과 같은 반례를 해결하지 못합니다.

2

20 2

20 2

답 : 40 / 수강생님 20

 

감사합니다.

0

인프런 AI 인턴

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

주어진 코드에서, 여러분의 로직을 살펴보니 우선 날짜 기준으로 강연을 정렬하고 반복문을 통해 최대 수익을 계산하려고 하신 것 같습니다. 하지만 이 구현 방식에서 몇 가지 문제가 발생할 수 있습니다.

  1. 정렬 기준: 우선, 강연을 오름차순으로 정렬해야 하는데 comp 함수는 하루를 기준으로 오름차순 정렬합니다. 단, 수익을 기준으로도 내림차순 정렬이 추가로 필요합니다. 이는 매일 가장 큰 수익을 가진 강연을 선택하기 위함입니다.

  2. 강연 중복 검사: 중복된 날짜에 대해 수익이 최대인 강연을 선택하도록 구현하셨지만, 이 부분에서 조건을 잘못 설정하면 불필요한 강연을 더하게 될 수 있습니다.

  3. 데이터 구조: deque라기보다는 priority_queue를 사용하여 항상 가장 큰 수익이 우선적으로 선택되도록 하는 것이 더 좋습니다.

해결 방법:
- pair<int, int>priority_queue 또는 vectorsort로 만들 수 있습니다. 날짜를 기준으로 정렬한 다음, 수익이 큰 순으로 순차적으로 선택하여 문제를 해결할 수 있습니다.

이 비슷한 질문과 해결 방법을 다룬 기존 답변이 있어 이를 참고하시길 바랍니다.

5-A 질문있습니다.

이 답변이 도움이 되었길 바라며, 추가적으로 궁금한 점이 있으시면 언제든지 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏

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

0

27

2

2주차 개념#12 트리 순회

0

20

2

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

0

244

2

백준 서비스 종료

9

776

1

sk 하이닉스 코테 대비

0

360

2

3-G 최댓값 질문

0

50

1

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

0

82

2

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

0

62

2

3-N 질문 있습니다.

0

66

2

학습방법

0

100

2

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

0

66

2

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

0

166

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

89

2

5-Q 질문

0

63

2

풀이 코드 질문

0

64

2