You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

35 lines
782 B

2 years ago
#include<bits/stdc++.h>
using namespace std;
#define NUM 50
void GreedySelector(int n, int s[], int f[], bool b[]) {
b[1]=true; //Ĭ<>Ͻ<EFBFBD><CFBD><EFBFBD>һ<EFBFBD><D2BB><EFBFBD><EFBFBD>Ȱ<EFBFBD><C8B0><EFBFBD>
int j=1; //<2F><>¼<EFBFBD><C2BC><EFBFBD><EFBFBD>һ<EFBFBD>μ<EFBFBD><CEBC><EFBFBD>b<EFBFBD>еĻ
//<2F><><EFBFBD>μ<EFBFBD><CEBC><EFBFBD><EFBFBD>i<EEB6AF>Ƿ<EFBFBD><C7B7>뵱ǰ<EBB5B1><C7B0>ѡ<EFBFBD><D1A1><EFBFBD>Ļ<C4BB><EEB6AF><EFBFBD><EFBFBD>
for(int i=2; i<=n; i++) {
if (s[i]>=f[j]) {
b[i]=true;
j=i;
} else
b[i]=false;
}
}
int main() {
int s[] = {0,1,3,0,5,3,5,6,8,8,2,12}; //<2F><EFBFBD><EFBFBD><EEB6AF>ʼʱ<CABC><CAB1>
int f[] = {0,4,5,6,7,8,9,10,11,12,13,14}; //<2F><EFBFBD><EFBFBD><EEB6AF><EFBFBD><EFBFBD>ʱ<EFBFBD><CAB1>
bool b[NUM]; //<2F><EFBFBD><E6B4A2><EFBFBD><EFBFBD><EFBFBD>ŵĻ<C4BB><EEB6AF><EFBFBD><EFBFBD>
int n = (sizeof(s) / sizeof(s[0])) - 1;
GreedySelector(n, s, f, b);
for(int i = 1; i <= n; i++) { //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ŵĻ<C4BB><EEB6AF><EFBFBD>ź<EFBFBD><C5BA><EFBFBD><EFBFBD>Ŀ<EFBFBD>ʼʱ<CABC><CAB1><EFBFBD>ͽ<EFBFBD><CDBD><EFBFBD>ʱ<EFBFBD><CAB1>
if(b[i]) cout << "<EFBFBD>" << i << " :" << "(" << s[i] << "," << f[i] << ")" <<endl;
}
return 0;
}