时间限制:3000 ms  |  内存限制:65535 KB
难度:4
 
描述
学校的小礼堂每天都会有许多活动,有时间这些活动的计划时间会发生冲突,需要选择出一些活动进行举办。小刘的工作就是安排学校小礼堂的活动,每个时间最多安排一个活动。现在小刘有一些活动计划的时间表,他想尽可能的安排更多的活动,请问他该如何安排。
 
输入
第一行是一个整型数m(m<100)表示共有m组测试数据。
每组测试数据的第一行是一个整数n(1<n<10000)表示该测试数据共有n个活动。
随后的n行,每行有两个正整数Bi,Ei(0<=Bi,Ei<10000),分别表示第i个活动的起始与结束时间(Bi<=Ei)
输出
对于每一组输入,输出最多能够安排的活动数量。
每组的输出占一行
样例输入
2
2
1 10
10 11
3
1 10
10 11
11 20
样例输出
1
2
提示
注意:如果上一个活动在t时间结束,下一个活动最早应该在t+1时间开始
 #include <stdio.h>
#include <string.h>
#include <stdlib.h>
typedef struct act{
int s;
int e;
}STACT;
int compare(const void *a, const void *b){
STACT *acts1 = (STACT *)a;
STACT *acts2 = (STACT *)b;
return (acts1->e - acts2->e);
}
int main()
{
//m:num of test,n:num of activities
int m,n;
int i;
scanf("%d", &m);
getchar();
while (m--) {
scanf("%d", &n);
getchar();
STACT *ats=(STACT *)malloc(sizeof(STACT)*n);
memset(ats, 0x00, sizeof(STACT)*n);
for (i = ; i < n; ++i) {
scanf("%d%d", &ats[i].s, &ats[i].e);
}
qsort(ats, n, sizeof(ats[]), compare);
int sum=;
int curTime=-;
for (i = ; i < n; ++i) {
if(curTime < ats[i].s){
++sum;
curTime = ats[i].e;
}
else {
continue;
}
}
printf("%d\n", sum);
if(ats != NULL){
free(ats);
ats=NULL;
}
}
return ;
}

Time: 172ms Space:316

 #include <stdio.h>
#include <string.h>
#include <stdlib.h>
struct act{
int s;
int e;
}actnode[];
int compare(const void *a, const void *b){
act *acts1 = (act *)a;
act *acts2 = (act *)b;
return (acts1->e - acts2->e);
}
int main()
{
//m:num of test,n:num of activities
int m,n;
int i;
scanf("%d", &m);
getchar();
while (m--) {
scanf("%d", &n);
getchar(); memset(&actnode , 0x00, sizeof(actnode));
for (i = ; i < n; ++i) {
scanf("%d%d", &actnode[i].s, &actnode[i].e);
}
qsort(actnode, n, sizeof(actnode[]), compare);
int sum=;
int curTime=-;
for (i = ; i < n; ++i) {
if(curTime < actnode[i].s){
++sum;
curTime = actnode[i].e;
}
else {
continue;
}
}
printf("%d\n", sum); }
return ;
}

212ms 392

 选择结束时间最早的,贪心算法

解体思路

有误:

 #include <iostream>
#include <string.h>
#include <algorithm>
#include <stdio.h>
using namespace std;
#define debug(x) cout << #x << " at line " << __LINE__ << " is: " << x << endl struct noac{
int Ti_s;
int Ti_e;
bool operator<(const noac& nc) const // DESC by Ti_s
{
return (Ti_s > nc.Ti_s);
}
friend void operator<<(ostream &os, const noac &nc)
{
os << nc.Ti_s << ' ' << nc.Ti_e << endl;
}
}tms[]; int main(){
int m,n;
scanf("%d", &m);
while (m--) {
scanf("%d", &n);
memset(&tms, , 0x00);
for (int i = ; i < n; ++i)
{
scanf("%d%d", &tms[i].Ti_s, &tms[i].Ti_e);
}
sort(tms, tms + n); int maxac = ;
for (int i = ; i < n; ++i)
{
int idx = i;
int sum = ;
for (int j = i+; j < n; ++j)
{
if(tms[idx].Ti_s >= tms[j].Ti_e)
{
++sum;
++idx;
}else
{
continue;
}
}
maxac = max(maxac, sum);
}
printf("%d\n", maxac);
}
return ;
}

比如说:

6
1 5
2 3
10 11
6 7
8 9
4 5

output: 4,而实际输出为5

14.会场安排问题(L4)的更多相关文章

  1. nyoj 14 会场安排问题(贪心专题)java

    会场安排问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:4   描述 学校的小礼堂每天都会有许多活动,有时间这些活动的计划时间会发生冲突,需要选择出一些活动进行举办.小刘的工 ...

  2. nyoj 14 会场安排问题(贪心专题)

    会场安排问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:4   描述 学校的小礼堂每天都会有许多活动,有时间这些活动的计划时间会发生冲突,需要选择出一些活动进行举办.小刘的工 ...

  3. nyoj 14 会场安排问题

    会场安排问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:4   描述 学校的小礼堂每天都会有许多活动,有时间这些活动的计划时间会发生冲突,需要选择出一些活动进行举办.小刘的工 ...

  4. NYOJ 14 会场安排问题(也算是经典问题了)

    会场安排问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:4 描述 学校的小礼堂每天都会有许多活动,有时间这些活动的计划时间会发生冲突,需要选择出一些活动进行举办.小刘的工作就 ...

  5. nyoj 题目14 会场安排问题

    会场安排问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:4   描述 学校的小礼堂每天都会有许多活动,有时间这些活动的计划时间会发生冲突,需要选择出一些活动进行举办.小刘的工 ...

  6. 基于贪心算法的几类区间覆盖问题 nyoj 12喷水装置(二) nyoj 14会场安排问题

    1)区间完全覆盖问题 问题描述:给定一个长度为m的区间,再给出n条线段的起点和终点(注意这里是闭区间),求最少使用多少条线段可以将整个区间完全覆盖 样例: 区间长度8,可选的覆盖线段[2,6],[1, ...

  7. 会场安排问题--nyoj题目14

    会场安排问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:4   描述 学校的小礼堂每天都会有许多活动,有时间这些活动的计划时间会发生冲突,需要选择出一些活动进行举办.小刘的工 ...

  8. ACM 会场安排问题

    会场安排问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:4   描述 学校的小礼堂每天都会有许多活动,有时间这些活动的计划时间会发生冲突,需要选择出一些活动进行举办.小刘的工 ...

  9. NYOJ 14 场地安排

    /* 中国标题的含义: 中国的翻译: 标题效果:寻求预定场地的最大数量,只有一个活动可以安排时间 解决问题的思路:然后使用结构数.之后再构建一个排序,排序结束时间活动.然后基于开始时间为大于一个事件的 ...

随机推荐

  1. effective c++ 笔记 (13-17)

    //---------------------------15/03/30---------------------------- //#13   以对象管理资源 { void f() { Inves ...

  2. 关于CMS的那点事 I

    CMS是Content Management System的缩写,意为"内容管理系统".CMS其实是一个很广泛的称呼,从一般的博客程序,新闻发布程序,到综合性的网站管理程序都可以被 ...

  3. eclipse中设置项目的编码方式

    1.windows->Preferences...打开"首选项"对话框,左侧导航树,导航到general->Workspace,右侧Text file encoding ...

  4. 阿里云容器服务区块链解决方案全新升级 支持Hyperledger Fabric v1.1

    摘要: 全球开源区块链领域影响最为广泛的Hyperledger Fabric日前宣布了1.1版本的正式发布,带来了一系列丰富的新功能以及在安全性.性能与扩展性等方面的显著提升.阿里云容器服务区块链解决 ...

  5. PAT甲题题解-1051. Pop Sequence (25)-堆栈

    将1~n压入最多为m元素的栈 给出k个出栈序列,问你是否能够实现. 能输出YES 否则NO 模拟一遍即可,水题. #include <iostream> #include <cstd ...

  6. Final阶段用户使用报告

    此作业要求参见:[https://edu.cnblogs.com/campus/nenu/2018fall/homework/2477] 组名:可以低头,但没必要 组长:付佳 组员:张俊余 李文涛 孙 ...

  7. YQCB冲刺第二周第七天

    今天的任务依旧为界面的美化. 遇到的问题为不熟悉css的使用. 站立会议 任务面板

  8. A总结

    Alpha 答辩总结 评审表 组名 格式 内容 ppt 演讲 答辩 总计 天机组 15 15 14 15 14 73 PMS 16 16 15 15 16 78 日不落战队 16 16 16 15 1 ...

  9. Mac用户抓包软件Charles 4.0 破解 以及 抓取Https链接设置

    相信大家曾经都是Window的用户,作为前端哪能没有一款抓包工具,抓包工具可以非常便捷的帮助我们分析接口返回报文数据,快速定位问题. 曾经横扫window用户的Fiddler便是我们的挚爱,然而,作为 ...

  10. week7:个人博客作业

    这周有2个需要注意的地方. 1,课上 这周是由张翼飞老师讲的课,上周已经听过老师讲的一节课了,这周发现,这个老师讲课是理论+案例,我每节课都在第一排坐的,我不知道其他人是什么想法,我是一上课,老师讲理 ...