算法训练 会议中心

时间限制:2.0s 内存限制:512.0MB

  会议中心  Siruseri政府建造了一座新的会议中心。许多公司对租借会议中心的会堂很感兴趣,他们希望能够在里面举行会议。

  对于一个客户而言,仅当在开会时能够独自占用整个会堂,他才会租借会堂。会议中心的销售主管认为:最好的策略应该是将会堂租借给尽可能多的客户。显然,有可能存在不止一种满足要求的策略。

  例如下面的例子。总共有4个公司。他们对租借会堂发出了请求,并提出了他们所需占用会堂的起止日期(如下表所示)。

上例中,最多将会堂租借给两家公司。租借策略分别是租给公司1和公司3,或是公司2和公司3,也可以是公司1和公司4。注意会议中心一天最多租借给一个公司,所以公司1和公司2不能同时租借会议中心,因为他们在第九天重合了。

  销售主管为了公平起见,决定按照如下的程序来确定选择何种租借策略:首先,将租借给客户数量最多的策略作为候选,将所有的公司按照他们发出请求的顺序编号。对于候选策略,将策略中的每家公司的编号按升序排列。最后,选出其中字典序最小[1]的候选策略作为最终的策略。

  例中,会堂最终将被租借给公司1和公司3:3个候选策略是{(1,3),(2,3),(1,4)}。而在字典序中(1,3)<(1,4)<(2,3)。

  你的任务是帮助销售主管确定应该将会堂租借给哪些公司。

输入格式

  输入的第一行有一个整数N,表示发出租借会堂申请的公司的个数。第2到第N+1行每行有2个整数。第i+1行的整数表示第i家公司申请租借的起始和终止日期。对于每个公司的申请,起始日期为不小于1的整数,终止日期为不大于109的整数。

输出格式

  输出的第一行应有一个整数M,表示最多可以租借给多少家公司。第二行应列出M个数,表示最终将会堂租借给哪些公司。

数据规模和约定

  对于50%的输入,N≤3000。在所有输入中,N≤200000。

样例输入

4

4 9

9 11

13 19

10 17

样例输出

2

1 3

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader; public class 会议中心 {
static int[] sqqs,sqzz,sqsx,sqcf,cxz,finz;
static int[][] dgb;
static int n=0,fin=0,max=0;
public static void main(String[] args)throws IOException {
BufferedReader reader=new BufferedReader(new InputStreamReader(System.in));
String s=reader.readLine();
n=Integer.parseInt(s);
sqqs=new int[n+1];
sqzz=new int[n+1];
sqcf=new int[n+1];
for(int i=1;i<=n;i++){
s=reader.readLine();
String[] sa = s.split(" ");
sqqs[i]=Integer.parseInt(sa[0]);
sqzz[i]=Integer.parseInt(sa[1]);
if (max<sqzz[i]) max=sqzz[i];
}
sqsx=new int[max+1];
for (int i=1;i<=n;i++){
if (sqsx[sqzz[i]]==0){
sqsx[sqzz[i]]=i;
}else{
if (sqqs[i]>sqqs[sqsx[sqzz[i]]]){
for (int j=1;j<=n;j++){
if (sqcf[j]==0){
sqcf[j]=sqsx[sqzz[i]];
sqsx[sqzz[i]]=i;
break;
}
}
}
}
}
dgb=new int[2][n+1];
for (int i=1;i<=max;i++) {
if (sqsx[i]!=0) {
getcs(sqsx[i]);
}
}
for (int i=1;i<=n;i++){
if (fin<dgb[0][i]) fin=dgb[0][i];
}
for (int k=max;k>=1;k--){
if (sqsx[k]==0) continue;
int i=sqsx[k];
if (dgb[0][i]==fin) continue;
for (int j=sqzz[i]+1;j<=max;j++){
if (j==max){
dgb[0][i]=0;
dgb[1][i]=0;
continue;
}
if (sqsx[j]==0) continue;
if (dgb[0][sqsx[j]]==0) continue;
if ((dgb[0][sqsx[j]]==dgb[0][i]+1)&(sqqs[sqsx[j]]>sqzz[i])) break;
if (dgb[0][sqsx[j]]>dgb[0][i]+1) {
dgb[0][i]=0;
dgb[1][i]=0;
break;
}
} }
for (int i=1;i<=n;i++) {
if (sqcf[i]!=0) {
getcs1(sqcf[i]);
} else break;
} cxz=new int[fin+1];
finz=new int[fin+1];
int xh=1;
for (int i=1;i<=n;i++){
if (dgb[0][i]==0) continue;
if (cxz[dgb[0][i]]!=0) continue;
if (fincheck(i)==1){
finz[xh]=i;
xh++;
cxz[dgb[0][i]]=i;
dealsq(i);
}
}
System.out.println(fin); for (int i=1;i<=fin;i++){
System.out.print(""+finz[i]+" ");
}
System.out.println();
}
static void getcs(int a){
int cs=0;
for (int i=sqqs[a]-1;i>0;i--){
if (sqsx[i]!=0){
cs=dgb[0][sqsx[i]];
if (cs!=0) {
break;
}
}
}
for (int i=sqqs[a];i<sqzz[a];i++){
if (sqsx[i]!=0){
if (dgb[0][sqsx[i]]>cs+1) return;
}
}
dgb[0][a]=cs+1;
dgb[1][a]=1;
}
static void getcs1(int a){
int cs=0;
int b=dgb[0][sqsx[sqzz[a]]];
if (b==0) return;
for (int i=sqqs[a]-1;i>0;i--){
if (sqsx[i]!=0){
cs=dgb[0][sqsx[i]];
if (cs!=0) {
break;
}
}
}
if (cs+1<b) return;
dgb[0][a]=cs+1;
dgb[1][a]=1;
}
static int fincheck(int a){
int[] lsst=new int[fin+1];
int b=0,c=0,sc=0,ec=0;
int cs=dgb[0][a];
for (int i=cs-1;i>=1;i--){
if (cxz[i]!=0) {
b=cxz[i];
sc=i;
break;
}
}
if (b!=0){
lsst[sc]=sqzz[b];
for (int i=sqzz[b]+1;i<sqqs[a];i++){
if (sqsx[i]==0) continue;
if (dgb[0][sqsx[i]]==0) continue;
if (lsst[dgb[0][sqsx[i]]]!=0) continue;
if (sqqs[sqsx[i]]<=lsst[dgb[0][sqsx[i]]-1]) continue;
lsst[dgb[0][sqsx[i]]]=sqzz[sqsx[i]];
}
if (lsst[cs-1]==0) return 0;
if (lsst[cs-1]>=sqqs[a]) return 0;
}
for (int i=cs+1;i<=fin;i++){
if (cxz[i]!=0){
c=cxz[i];
ec=i;
break;
}
}
if (c!=0){
lsst[ec]=sqqs[c];
for (int i=sqqs[c]-1;i>sqzz[a];i--){
if (sqsx[i]==0) continue;
if (dgb[0][sqsx[i]]==0) continue;
if (i>=lsst[dgb[0][sqsx[i]]+1]) continue;
lsst[dgb[0][sqsx[i]]]=Math.max(sqqs[sqsx[i]],lsst[dgb[0][sqsx[i]]]);
}
if (lsst[cs+1]==0) return 0;
if (lsst[cs+1]<=sqzz[a]) return 0;
}
return 1;
}
static void dealsq(int a){
int cs=dgb[0][a];
for (int i=sqzz[a]-1;i>=1;i--){
if (sqsx[i]==0) continue;
if (dgb[0][sqsx[i]]==0) continue;
int dcs=dgb[0][sqsx[i]];
if (dcs==cs) {
dgb[0][sqsx[i]]=0;
dgb[1][sqsx[i]]=0;
continue;
}
if (dcs==cs-1) {
if (i>=sqqs[a]) {
dgb[0][sqsx[i]]=0;
dgb[1][sqsx[i]]=0;
continue;
}
}
if (dcs==cs-2) break;
}
for (int i=sqzz[a]+1;i<=max;i++){
if (sqsx[i]==0) continue;
if (dgb[0][sqsx[i]]==0) continue;
int dcs=dgb[0][sqsx[i]];
if (dcs==cs) {
dgb[0][sqsx[i]]=0;
dgb[1][sqsx[i]]=0;
continue;
}
if (dcs==cs+1) {
if (sqzz[a]>=sqqs[sqsx[i]]) {
dgb[0][sqsx[i]]=0;
dgb[1][sqsx[i]]=0;
continue;
}
}
if (dcs==cs+2) break;
}
} }

Java实现 蓝桥杯VIP 算法训练 会议中心的更多相关文章

  1. Java实现蓝桥杯VIP 算法训练 找公倍数

    问题描述 这里写问题描述. 打印出1-1000所有11和17的公倍数. 样例输入 一个满足题目要求的输入范例. 样例输出 与上面的样例输入对应的输出. 这道题其实没有什么可写的,但是为了让读者更方便的 ...

  2. Java实现 蓝桥杯VIP 算法训练 连通分块(并查集)

    试题 算法训练 连通分块 资源限制 时间限制:200ms 内存限制:8.0MB 问题描述 连通分块 输入格式 输入的第一行包含两个整数n, m n代表图中的点的个数,m代表边的个数 接下来m行,每行2 ...

  3. Java实现 蓝桥杯VIP 算法训练 无权最长链

    试题 算法训练 无权最长链 问题描述 给定一个n节点m边的无圈且连通的图,求直径 输入格式 第一行两个数字n,m 接下来m行每行两个数字x,y,代表x,y之间有一条边 输出格式 要求用户的输出满足的格 ...

  4. Java实现 蓝桥杯VIP 算法训练 星际交流

    算法训练 星际交流 时间限制:1.0s 内存限制:256.0MB 问题描述 人类终于登上了火星的土地并且见到了神秘的火星人.人类和火星人都无法理解对方的语言,但是我们的科学家发明了一种用数字交流的方法 ...

  5. Java实现 蓝桥杯VIP 算法训练 Car的旅行路线

    大家可以看一下这个,蓝桥杯官网的这道题是有问题的 Car的旅行路线 算法训练 Car的旅行路线 时间限制:1.0s 内存限制:256.0MB 提交此题 锦囊1 锦囊2 查看参考代码 问题描述 又到暑假 ...

  6. Java实现 蓝桥杯VIP 算法训练 最大质因数(暴力)

    试题 算法训练 最大质因数 问题描述 给出N个数字,求出有最大的最大质因数的那个数 输入格式 第一行:一个整数N. 接下来的N行,每行一个整数A_i,表示给出的那N个数字. 输出格式 第一行:一个整数 ...

  7. Java实现 蓝桥杯VIP 算法训练 与1连通的点的个数(并查集)

    试题 算法训练 与1连通的点的个数 资源限制 时间限制:1.0s 内存限制:256.0MB 问题描述 没有问题描述. 输入格式 输入的第一行包含两个整数n, m n代表图中的点的个数,m代表边的个数 ...

  8. Java实现 蓝桥杯VIP 算法训练 非递归(暴力)

    试题 算法训练 非递归 问题描述 当x>1时,Hermite多项式的定义见第二版教材125页.用户输入x和n,试编写"非递归"函数,输出对应的Hermite多项式的值.其中x ...

  9. Java实现 蓝桥杯VIP 算法训练 步与血(递推 || DFS)

    试题 算法训练 步与血 问题描述 有n*n的方格,其中有m个障碍,第i个障碍会消耗你p[i]点血.初始你有C点血,你需要从(1,1)到(n,n),并保证血量大于0,求最小步数. 输入格式 第一行3个整 ...

随机推荐

  1. Spring方法注入的使用与实现原理

    一.前言   这几天为了更详细地了解Spring,我开始阅读Spring的官方文档.说实话,之前很少阅读官方文档,就算是读,也是读别人翻译好的.但是最近由于准备春招,需要了解很多知识点的细节,网上几乎 ...

  2. JVM入门--类加载器

    一.基础架构 概览 我们平时说的栈是指的Java栈,native method stack 里面装的都是native方法 细节架构图 二.类加载器 1.类的加载 方法区并不是存放方法的区域,其是存放类 ...

  3. Web_python_template_injection

    0x01 pthon模板注入 判断是否为模板注入 paload http://124.126.19.106:34164/{{1+1}} //如果里面的值被执行了,那么存在模板注入 //调用os模块的p ...

  4. mac下charles使用

    设置charles  电脑上一次性的工作 1 下载下面两个文件(这里版本自己定) a charles-proxy-4.1.4.dmg b charles4.1.4的副本.jar 2 进行charles ...

  5. centos6 升级gcc 无法识别的命令行选项“-std=gnu++1y”的解决办法

    npm install 提示: 1.下载源文件,并安装: wget http://people.centos.org/tru/devtools-2/devtools-2.repo mv devtool ...

  6. httpd+tomcat 均衡负载

    接前面的文章http://www.cnblogs.com/gqdw/p/3785812.html workers.properties worker.list=controller#worker1 w ...

  7. spark机器学习从0到1基本的统计工具之(三)

      给定一个数据集,数据分析师一般会先观察一下数据集的基本情况,称之为汇总统计或者概要性统计.一般的概要性统计用于概括一系列观测值,包括位置或集中趋势(比如算术平均值.中位数.众数和四分位均值),展型 ...

  8. rasdaman介绍及安装

    一.分布式介绍 Rasdaman中的主节点称为Rasdaman的主机,它充当中央Rasdaman请求分派器并且控制所有服务器进程.Rasdaman管理器接收客户机请求并将这些请求分配给服务器进程.服务 ...

  9. uefi win10 Ubuntu 18的安装

    uefi win10 Ubuntu 18的安装 (Ubuntu折腾的第一天) 安装时的踩坑记录

  10. 汉字统计(hdu2030)

    输入格式:一个整型,再循环带有空格的字符串 思考:用scanf_s()函数输入整型,然后一个大循环,再用gets_s()函数输入带空格的字符串. 注意:scanf_s()函数多加了%c,&d, ...