Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- mysqld.sock
- 걷는건귀찮아
- 윈도우
- 18249
- 알고리즘
- 알고리즘 목차
- 회의실 배정
- 원형
- 2020 KAKAO BLIND RECRUITMENT
- 자료구조 목차
- AI Hub
- 유니티
- 문자열 압축
- MySQL
- 우분투
- c#
- 탄막
- 백준
- SWEA
- 토글 그룹
- 영상 프레임 추출
- 강의실2
- 그리디알고리즘
- 탄막 스킬 범위
- 수 만들기
- 마우스 따라다니기
- 탄막 이동
- 3344
- 3273
- 단어 수학
Archives
- Today
- Total
와이유스토리
[DFS 중복순열] 프로그래머스 이모티콘 할인행사 C++ 본문
#include <string>
#include <vector>
using namespace std;
int discount[8];
vector<int> answer(2, 0);
// 사용자 금액 계산
void check(vector<vector<int>> users, vector<int> emoticons) {
int cnt = 0;
int sales = 0;
for(int i=0; i<users.size(); i++) {
int price = 0;
for(int j=0; j<emoticons.size(); j++) {
// 이모티콘 구입
if (users[i][0] <= discount[j]) {
price += emoticons[j]*(100-discount[j])*0.01;
}
}
// 이모티콘 플러스 서비스 가입
if (price >= users[i][1]) cnt++;
else sales += price;
}
// 최대 가입자 수 및 매출액
answer = max(answer, {cnt, sales});
}
// 이모티콘 - 할인율 DFS 중복 순열
void dfs(int depth, vector<vector<int>> users, vector<int> emoticons) {
if (depth == emoticons.size()) {
// 사용자 금액 계산
check(users, emoticons);
return;
}
for(int i=1; i<=4; i++) {
discount[depth] = i*10;
dfs(depth+1, users, emoticons);
}
}
vector<int> solution(vector<vector<int>> users, vector<int> emoticons) {
// 이모티콘 - 할인율 DFS 중복 순열
dfs(0, users, emoticons);
return answer;
}
#include <string>
#include <vector>
#include <set>
#include <iostream>
using namespace std;
set<int> s;
int discount[8];
int maxCnt, maxSales;
// 사용자 금액 계산
void check(vector<vector<int>> users, vector<int> emoticons) {
int cnt = 0;
int sales = 0;
for(int i=0; i<users.size(); i++) {
int price = 0;
for(int j=0; j<emoticons.size(); j++) {
// 이모티콘 구입
if (users[i][0] <= discount[j]) {
price += emoticons[j]*(100-discount[j])*0.01;
}780 1095 1088 2940 5903 5903 4808
}
// 이모티콘 플러스 서비스 가입
if (price >= users[i][1]) cnt++;
else sales += price;
}
if (cnt == 4) cout << cnt << " " << sales << "\n";
if (cnt > maxCnt) {
maxCnt = cnt;
maxSales = sales;
}
else if ((cnt == maxCnt) &&(sales > maxSales)) {
maxSales = sales;
}
}
// 이모티콘 - 할인율 DFS 중복 순열
void dfs(int depth, vector<vector<int>> users, vector<int> emoticons) {
if (depth == emoticons.size()) {
check(users, emoticons);
for(int i=0; i<emoticons.size(); i++) {
cout << discount[i] <<" ";
}
cout << "\n";
return;
}
for(auto e : s) {
discount[depth] = e;
dfs(depth+1, users, emoticons);
}
}
vector<int> solution(vector<vector<int>> users, vector<int> emoticons) {
ios_base::sync_with_stdio(0);
cin.tie(0); cout.tie(0);
// 할인율 집합
for(int i=0; i<users.size(); i++) s.insert(users[i][0]);
// 이모티콘 - 할인율 DFS 중복 순열
dfs(0, users, emoticons);
vector<int> answer;
answer.push_back(maxCnt);
answer.push_back(maxSales);
return answer;
}
'코딩테스트 > 그래프|트리' 카테고리의 다른 글
[DFS 순열, 그래프, 비트] 프로그래머스 양과 늑대 C++ (0) | 2023.02.11 |
---|---|
[DFS 순열] 프로그래머스 양궁대회 C++ (0) | 2023.01.21 |
[DFS 순열] 백준 17406 배열 돌리기 4 C++ (0) | 2022.02.05 |
[DFS 2번(조합, 단순), 비트마스킹] (CHECK) 백준 17471 게리맨더링 C++ (0) | 2022.02.04 |
[DFS 단순 반복] 프로그래머스 카카오프렌즈 컬러링북 C++ (0) | 2022.02.04 |
Comments