题目描述
图书馆占位的很厉害,只要去晚了一会就没有位置了。有些人占着位置却不来自习,这就造成了资源的浪费。现在我们的问题是一天当中有n个同学可能会来到同一个座位,假设上面有人则另外找座位,若没有人,则就可以占据此位置,直至你离开为止。为了最大化利用图书馆资源,我们要求的问题是一个位置最多能够被几个同学来用过。
输入
第一行为n个同学 (1 <=n<=10000)
接下来n行就是每个同学的进入图书馆的时间和离开图书馆的时间,为了简化问题,我们假设时间值为整数。
输出
输出一个座位最多被几位同学占据。
样例输入
6
1 3
2 4
3 6
7 9
10 11
5 7
样例输出
4
//贪心算法
#include<bits/stdc++.h>
using namespace std;
struct library{
int x;
int y;
}s[10000];
bool mycmp(library &m,library &n){
if(m.x!=n.x)return m.x>n.x;
else return m.y<n.y;
}
int main(){
int n;
while(cin>>n){
for(int i=0;i<n;i++)cin>>s[i].x>>s[i].y;
sort(s,s+n,mycmp);
int sum=1;
int a=s[0].x;
for(int i=1;i<n;i++){
if(s[i].y<=a){
a=s[i].x;
sum++;
}
}
cout<<sum<<endl;
}
return 0;
}
图书馆占位.java
import java.util.Arrays;
import java.util.Comparator;
import java.util.Scanner;
class library{
int start;
int end;
library(int start,int end){
this.start = start;
this.end = end;
}
}
public class Main {
public static void main(String[] args){
Scanner cin = new Scanner(System.in);
int n = cin.nextInt();
library []libraries = new library[n];
for(int i=0;i<n;i++){
libraries[i] = new library(cin.nextInt(),cin.nextInt());
}
int ans = 0;
Arrays.sort(libraries, new Comparator<library>() {
@Override
public int compare(library o1, library o2) {
return o1.end - o2.end;
}
});
int cnt = 0;
for(library i : libraries){
if(i.start >= cnt){
ans++;
cnt = i.end;
}
}
System.out.println(ans);
}
}