[hihoCoder] 任务分配 解题报告

原创 2016年05月30日 12:12:19

时间限制:10000ms
单点时限:1000ms
内存限制:256MB

描述

给定 N 项任务的起至时间( S1E1 ), ( S2E2 ), ..., ( SNEN ), 计算最少需要多少台机器才能按时完成所有任务。

同一时间一台机器上最多进行一项任务,并且一项任务必须从头到尾保持在一台机器上进行。任务切换不需要时间。

输入

第一行一个整数 N,(1 ≤ N ≤ 100000),表示任务的数目。 以下 N 行每行两个整数 SiEi,(0 ≤ Si < Ei ≤ 1000000000),表示任务的起至时间。

输出

输出一个整数,表示最少的机器数目。

样例输入
5
1 10
2 7
6 9
3 4
7 10
样例输出
3

思路: 要计算最大重叠区间的, 我们可以先以起始位置排序. 然后遍历数组, 每次将终点加入到二叉排序树set中, 如果当前的起点比set中的某个终点大, 就从set中将那个终点删除掉, 这样set最大的长度即是最大的重叠区间数目.

代码如下:

/*************************************************************************
	> File Name: schedu.cpp
	> Author: Maoting Ren
	> Mail: mren@g.clemson.edu
	> Created Time: Sun 29 May 2016 03:41:34 PM EDT
 ************************************************************************/

#include<iostream>
#include<vector>
#include<set>
#include<algorithm>
using namespace std;

int main()
{
    int N, start, end, Max = 0;
    vector<pair<int, int> > time;
    multiset<int> st;
    cin>>N;
    for(int i = 0; i < N; i++)
    {
        cin >> start >> end; 
        time.push_back(make_pair(start, end));
    }
    sort(time.begin(), time.end());
    for(int i = 0; i< (int)time.size(); i++)
    {
        set<int>::iterator it = st.begin();
        while(it != st.end())
        {
            if(time[i].first >= *it) it = st.erase(it);
            else break;
        }
        st.insert(time[i].second);
        Max = max(Max, (int)st.size());
    }        
    cout << Max << endl;
    return 0;
}




版权声明:本文为博主原创文章,未经博主允许不得转载。

hihocoder #1309 : 任务分配

//http://www.spoj.com/MIT071/problems/ROMANRDS/ #pragma comment(linker, "/STACK:102400000,102400000...
  • chenwenwen1989
  • chenwenwen1989
  • 2016年08月12日 19:49
  • 185

【任务分配】解题报告

题目描述 图书馆按顺序排列有N本书需要维护,每本书的总页数不相同。现有M位员工。可以给每个员工分配连续的一段书籍,让他进行维护。现在的问题是,怎么样分配,工作任务最重(需要维护的页数最多)的...
  • wu_yihao
  • wu_yihao
  • 2011年11月08日 21:31
  • 578

任务分配hihocoder 1309(离散化 )

题目链接:http://hihocoder.com/problemset/problem/1309 描述 给定 N 项任务的起至时间( S1, E1 ), ( S2, E2 ), ....
  • xiaolonggezte
  • xiaolonggezte
  • 2017年07月18日 19:59
  • 92

贪心算法实例(一):多任务分配问题

贪心算法多任务分配
  • u012845311
  • u012845311
  • 2017年06月17日 09:37
  • 649

任务分配问题(匈牙利算法)

全文搬运自  http://www.cnblogs.com/dwdxdy/p/3261742.html  (仅作收藏之用) 【算法题】任务分配问题---匈牙利算法 一、问题描述...
  • qq_25945437
  • qq_25945437
  • 2017年04月27日 00:21
  • 680

算法设计与分析——任务分配问题

【问题描述】假设有n个任务需要分配给n个人执行,每个人只执行一个任务,每个任务只由一个人执行。第i个人执行第j个任务的成本是Cij(1...
  • qq_28666193
  • qq_28666193
  • 2016年11月26日 16:01
  • 2905

hihocoder#1039 : 字符消除

自己写的,实例没错,但是提交WA#include #include using namespace std;string str_remain(string str){ string::ite...
  • gao1440156051
  • gao1440156051
  • 2015年09月24日 21:47
  • 726

分支界限法 任务分配问题

2.5.1题目描述 分配问题要求将n个任务分配给n给人,每个人完成任务的代价不同,要求分配的结果最优,此题可以使用回溯求解。 2.5.2程序使用说明 Java环境1.8.0_111 IDE:eclip...
  • mymy_blog
  • mymy_blog
  • 2017年01月19日 21:45
  • 1608

【hihocoder】1014. Trie树

hihocoder, trie树
  • zone_programming
  • zone_programming
  • 2015年09月25日 16:31
  • 1138

[hihoCoder] #1306 : 股票价格 解题报告

题目链接: http://hihocoder.com/problemset/problem/1306 时间限制:20000ms 单点时限:2000ms 内存限制:256MB ...
  • qq508618087
  • qq508618087
  • 2016年05月30日 11:57
  • 428
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:[hihoCoder] 任务分配 解题报告
举报原因:
原因补充:

(最多只允许输入30个字)