博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ny14 会场安排问题
阅读量:6879 次
发布时间:2019-06-26

本文共 1457 字,大约阅读时间需要 4 分钟。

会场安排问题

时间限制:
3000 ms  |  内存限制:
65535 KB
难度:
4
 
描述
学校的小礼堂每天都会有许多活动,有时间这些活动的计划时间会发生冲突,需要选择出一些活动进行举办。小刘的工作就是安排学校小礼堂的活动,每个时间最多安排一个活动。现在小刘有一些活动计划的时间表,他想尽可能的安排更多的活动,请问他该如何安排。
 
输入
第一行是一个整型数m(m<100)表示共有m组测试数据。
每组测试数据的第一行是一个整数n(1<n<10000)表示该测试数据共有n个活动。
随后的n行,每行有两个正整数Bi,Ei(0<=Bi,Ei<10000),分别表示第i个活动的起始与结束时间(Bi<=Ei)
输出
对于每一组输入,输出最多能够安排的活动数量。
每组的输出占一行
样例输入
221 1010 1131 1010 1111 20
样例输出
12 AC代码

#include<stdio.h>

#include<string.h>
int main()
{
 int n,t,x,y,max,min,i,j,m;
 int a[100005];
 scanf("%d",&m);
 while(m--)
 {  
  memset(a,0,sizeof(a));
  scanf("%d",&t);
      max=0;n=t;
     for(i=0;i<t;i++)
  {
        scanf("%d%d",&x,&y);
        if(a[y]!=0)
  {
       if(x>a[y])
        a[y]=x;//相当于按结束时间进行排序
  }
  else a[y]=x;
  }

        for(i=0;i<=10000;i++)

   if(a[i]!=0)
   {min=i;break;}

 for(i=min;i<=10000;i++)

     if(a[i]>min && a[i]!=0)
  {
   min=i;
      max++;
  }
     printf("%d\n",max+1);//1是第一个节目;
 }
 return 0;
}

  按照杭电上的2037 “今年暑假不AC”,超时了 
#include<stdio.h>
int main()
{
 int n,t,x,y,max,min,i,j,m;
 int a[100005],b[100005];
 scanf("%d",&m);
 while(m--)
 {   scanf("%d",&t);
  max=0;n=t;
  for(i=0;i<t;i++)
   scanf("%d%d",&a[i],&b[i]);
  for(j=0;j<n-1;j++)//对末尾的时间进行排序,开始的时间也随之变化着,
   for(i=0;i<n-1-j;i++)
    if(b[i]>b[i+1])
    {
     x=a[i];a[i]=a[i+1];a[i+1]=x;
     y=b[i];b[i]=b[i+1];b[i+1]=y;
    }
             //for(i=0;i<t;i++)
     //  printf("%d ",b[i]);
    min=b[0];//排完序后,第一个结束的时间是最小的,所以第一个节目肯定要看,然后如果下一次的开始时间,小于说所录的最小的结束时间,则观看这个节目,
    for(i=1;i<n;i++)
     if(a[i]>min)
     {
      min=b[i];//最小的是节目结束的时间,不断的变化着;
      max++;
     }
     printf("%d\n",max+1);//1是第一个节目;
 }
 return 0;
}
       

转载于:https://www.cnblogs.com/lovychen/p/3190977.html

你可能感兴趣的文章
使用 LogStash 归集日志
查看>>
我的友情链接
查看>>
我的友情链接
查看>>
德国博世百年风雨启示录(下):实业强国
查看>>
(整理)用Elixir做一个多人扑克游戏 4
查看>>
关于架构
查看>>
The application’s PagerAdapter changed the adapter’s contents without calling PagerA
查看>>
qcom 跨平台的串口调试工具 PKGBUILD
查看>>
Delphi 时间格式化,动态显示时间,显示最新时间
查看>>
在JAVA中将NEW一分为2,分步进行[反射机制产生类]
查看>>
Java多态性的两个特殊情况
查看>>
我的友情链接
查看>>
怎么改变Win7登陆背景图片
查看>>
虚拟带库和物理带库比较
查看>>
AD委派加域权限
查看>>
在Delphi 7中使用加密的SQLite
查看>>
wordpress 无用的RSS Feed Cache
查看>>
Linux Vi编辑器的基本使用方法
查看>>
HTTP头域列表与解释 之 response篇
查看>>
一切属他,则名为苦;一切由己,自在安乐。
查看>>