각 작업에 세 개의 매개변수가 있는 N개의 작업 목록이 있다고 가정합니다. 1. 시작 시간 2. 종료 시간 3. 이익 우리는 하위 집합의 두 작업이 겹치지 않도록 최대 이익과 관련된 작업 하위 집합을 찾아야 합니다.
따라서 입력이 N =4 및 J ={{2, 3, 55},{4, 6, 25},{7, 20, 150},{3, 150, 250}} 인 경우 출력은 [(2, 3, 55),(3, 150, 250)] 및 최적 이익 305
이 문제를 해결하기 위해 다음 단계를 따릅니다. −
-
find_no_conflict() 함수를 정의하면 배열 작업, 인덱스,
가 필요합니다. -
왼쪽 :=0, 오른쪽 :=인덱스 - 1
-
왼쪽 <=오른쪽 동안 −
-
중간 :=(왼쪽 + 오른쪽) / 2
-
job[mid].finish <=jobs[index].start이면 -
-
작업[mid + 1].finish <=작업[index].start이면 -
-
왼쪽 :=중간 + 1
-
-
중간 반환
-
중간 반환
-
-
-
그렇지 않으면
-
오른쪽 :=중간 - 1
-
-
-
반환 -1
-
기본 방법에서 다음을 수행하십시오 -
-
완료 시간에 따라 배열 job_list 정렬
-
크기가 n인 테이블이라는 작업에 대한 테이블을 만듭니다.
-
table[0].value :=job_list[0].profit
-
테이블[0]의 끝에 job_list[0] 삽입
-
initialize i :=1의 경우, i
-
include_profit :=job_list[i].profit
-
l :=find_no_conflict(작업 목록, i)
-
l이 -1과 같지 않으면 -
-
include_profit :=include_profit + 테이블[l].value
-
-
include_profit> table[i - 1].value이면 -
-
table[i].value :=include_profit
-
테이블[i].작업 :=테이블[l].작업
-
테이블[i]의 끝에 job_list[i] 삽입
-
-
그렇지 않으면
-
테이블[i] :=테이블[i - 1]
-
-
-
테이블에서 작업 표시
-
표시 최적 이익 :=table[n - 1].value
예시(C++)
이해를 돕기 위해 다음 구현을 살펴보겠습니다. −
#include <bits/stdc++.h>
using namespace std;
class Job {
public:
int start, finish, profit;
};
struct job_with_weight {
vector<Job> job;
int value;
};
bool jobComparator(Job s1, Job s2) {
return (s1.finish < s2.finish);
}
int find_no_conflict(Job jobs[], int index) {
int left = 0, right = index - 1;
while (left <= right) {
int mid = (left + right) / 2;
if (jobs[mid].finish <= jobs[index].start) {
if (jobs[mid + 1].finish <= jobs[index].start)
left = mid + 1;
else
return mid;
}
else
right = mid - 1;
}
return -1;
}
int get_max_profit(Job job_list[], int n) {
sort(job_list, job_list + n, jobComparator);
job_with_weight table[n];
table[0].value = job_list[0].profit;
table[0].job.push_back(job_list[0]);
for (int i = 1; i < n; i++) {
int include_profit = job_list[i].profit;
int l = find_no_conflict(job_list, i);
if (l != - 1)
include_profit += table[l].value;
if (include_profit > table[i - 1].value){
table[i].value = include_profit;
table[i].job = table[l].job;
table[i].job.push_back(job_list[i]);
}
else
table[i] = table[i - 1];
}
cout << "[";
for (int i=0; i<table[n-1].job.size(); i++) {
Job j = table[n-1].job[i];
cout << "(" << j.start << ", " << j.finish << ", " << j.profit << "),";
}
cout << "]\nOptimal profit: " << table[n - 1].value;
}
int main() {
Job arr[] = {{2, 3, 55},{4, 6, 25},{7, 20, 150},{3, 150, 250}};
int n = sizeof(arr)/sizeof(arr[0]);
get_max_profit(arr, n);
} 입력
{{2, 3, 55},{4, 6, 25},{7, 20, 150},{3, 150, 250}} 출력
[(2, 3, 55),(3, 150, 250),] Optimal profit: 305