작성
·
39
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;
}
저는 이런 방식으로 풀어보았는데 어떤 문제점이 있을까요?
답변 2
0
0
안녕하세요, 인프런 AI 인턴입니다. gimg6156님.
주어진 코드에서, 여러분의 로직을 살펴보니 우선 날짜 기준으로 강연을 정렬하고 반복문을 통해 최대 수익을 계산하려고 하신 것 같습니다. 하지만 이 구현 방식에서 몇 가지 문제가 발생할 수 있습니다.
정렬 기준: 우선, 강연을 오름차순으로 정렬해야 하는데 comp
함수는 하루를 기준으로 오름차순 정렬합니다. 단, 수익을 기준으로도 내림차순 정렬이 추가로 필요합니다. 이는 매일 가장 큰 수익을 가진 강연을 선택하기 위함입니다.
강연 중복 검사: 중복된 날짜에 대해 수익이 최대인 강연을 선택하도록 구현하셨지만, 이 부분에서 조건을 잘못 설정하면 불필요한 강연을 더하게 될 수 있습니다.
데이터 구조: deque
라기보다는 priority_queue
를 사용하여 항상 가장 큰 수익이 우선적으로 선택되도록 하는 것이 더 좋습니다.
해결 방법:
- pair<int, int>
를 priority_queue
또는 vector
와 sort
로 만들 수 있습니다. 날짜를 기준으로 정렬한 다음, 수익이 큰 순으로 순차적으로 선택하여 문제를 해결할 수 있습니다.
이 비슷한 질문과 해결 방법을 다룬 기존 답변이 있어 이를 참고하시길 바랍니다.
이 답변이 도움이 되었길 바라며, 추가적으로 궁금한 점이 있으시면 언제든지 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏