我写的是不完美算法!!!

题面

Description

在大学期间,经常需要租借教室。大到院系举办活动,小到学习小组自习讨论,都需要 向学校申请借教室。教室的大小功能不同,借教室人的身份不同,借教室的手续也不一样。

面对海量租借教室的信息,我们自然希望编程解决这个问题。

我们需要处理接下来n天的借教室信息,其中第i天学校有ri个教室可供租借。共有m份 订单,每份订单用三个正整数描述,分别为dj,sj,tj,表示某租借者需要从第sj天到第tj天租 借教室(包括第sj天和第tj天),每天需要租借dj个教室。

我们假定,租借者对教室的大小、地点没有要求。即对于每份订单,我们只需要每天提 供dj个教室,而它们具体是哪些教室,每天是否是相同的教室则不用考虑。

借教室的原则是先到先得,也就是说我们要按照订单的先后顺序依次为每份订单分配教 室。如果在分配的过程中遇到一份订单无法完全满足,则需要停止教室的分配,通知当前申 请人修改订单。这里的无法满足指从第sj天到第tj天中有至少一天剩余的教室数量不足dj个。

现在我们需要知道,是否会有订单无法完全满足。如果有,需要通知哪一个申请人修改 订单。

Input

第一行包含两个正整数n,m,表示天数和订单的数量。

第二行包含n个正整数,其中第i个数为ri,表示第i天可用于租借的教室数量。

接下来有m行,每行包含三个正整数dj,sj,tj,表示租借的数量,租借开始、结束分别在 第几天。

每行相邻的两个数之间均用一个空格隔开。天数与订单均用从1开始的整数编号。

Output

如果所有订单均可满足,则输出只有一行,包含一个整数 0。否则(订单无法完全满足) 输出两行,第一行输出一个负整数-1,第二行输出需要修改订单的申请人编号。

Sample Input

4 3

2 5 4 3

2 1 3

3 2 4

4 2 4

Sample Output

-1

2

Hint

第 1 份订单满足后,4 天剩余的教室数分别为 0,3,2,3。第 2 份订单要求第 2 天到 第 4 天每天提供 3 个教室,而第 3 天剩余的教室数为 2,因此无法满足。分配停止,通知第 2 个申请人修改订单。

题解

这道题目和原来写过的庙会班车如出一辙

但是,这道题目甚至都不需要贪心,只需要单纯的维护区间即可(普通的线段树并不是正解。。。只是用这道题目来练习而已)

庙会班车的题解

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstring>
  4. #include<cstdlib>
  5. #include<cmath>
  6. #include<algorithm>
  7. using namespace std;
  8. #define MAX 1000100
  9. struct tree
  10. {
  11. int l,r;
  12. int num;
  13. int lazy;
  14. }T[MAX*4];
  15. int Cr[MAX];
  16. int n,m,a,b,c,d;
  17. void Build(int k,int l,int r)
  18. {
  19. T[k]=(tree){l,r,0,0};
  20. if(l==r)
  21. {
  22. T[k].num=Cr[l];
  23. return;
  24. }
  25. int mid=(l+r)>>1;
  26. Build(k*2,l,mid);
  27. Build(k*2+1,mid+1,r);
  28. T[k].num=min(T[k*2].num,T[k*2+1].num);
  29. }
  30. void Down(int k)
  31. {
  32. if(T[k].l==T[k].r)
  33. {
  34. T[k].num+=T[k].lazy;
  35. T[k].lazy=0;
  36. return;
  37. }
  38. T[k].num+=T[k].lazy;
  39. T[k*2].lazy+=T[k].lazy;
  40. T[k*2+1].lazy+=T[k].lazy;
  41. T[k].lazy=0;
  42. }
  43. void Update(int k,int L,int R,int w)
  44. {
  45. Down(k);
  46. if(T[k].l==L&&T[k].r==R)
  47. {
  48. T[k].lazy+=w;
  49. Down(k);
  50. return;
  51. }
  52. int mid=(T[k].l+T[k].r)>>1;
  53. if(L<=mid&&R>mid)
  54. {
  55. Update(k*2,L,mid,w);
  56. Update(k*2+1,mid+1,R,w);
  57. }
  58. else
  59. if(L>mid)
  60. Update(k*2+1,L,R,w);
  61. else
  62. if(R<=mid)
  63. Update(k*2,L,R,w);
  64. Down(k*2);
  65. Down(k*2+1);
  66. T[k].num=min(T[k*2].num,T[k*2+1].num);
  67. }
  68. int Query(int k,int L,int R)
  69. {
  70. Down(k);
  71. if(T[k].l==L&&T[k].r==R)
  72. return T[k].num;
  73. int mid=(T[k].l+T[k].r)>>1;
  74. int re=2000000000;
  75. if(L<=mid&&R>mid)
  76. {
  77. re=min(re,Query(k*2,L,mid));
  78. re=min(re,Query(k*2+1,mid+1,R));
  79. }
  80. else
  81. if(L>mid)
  82. re=Query(k*2+1,L,R);
  83. else
  84. if(R<=mid)
  85. re=Query(k*2,L,R);
  86. Down(k*2);
  87. Down(k*2+1);
  88. T[k].num=min(T[k*2].num,T[k*2+1].num);
  89. return re;
  90. }
  91. inline int read()
  92. {
  93. int x=0,t=1;char ch=getchar();
  94. while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
  95. if(ch=='-')t=-1,ch=getchar();
  96. while(ch>='0'&&ch<='9'){x=x*10+ch-48;ch=getchar();}
  97. return x*t;
  98. }
  99. int main()
  100. {
  101. n=read();m=read();
  102. for(int i=1;i<=n;++i)
  103. Cr[i]=read();
  104. Build(1,1,n);
  105. for(int i=1;i<=m;++i)
  106. {
  107. a=read();b=read();c=read();
  108. d=Query(1,b,c);
  109. if(a>d)
  110. {
  111. cout<<-1<<endl<<i<<endl;
  112. return 0;
  113. }
  114. Update(1,b,c,-a);
  115. }
  116. cout<<0<<endl;
  117. return 0;
  118. }

【NOIP2012】【CJOJ1093】【洛谷1083】借教室的更多相关文章

  1. [NOIP2012] 提高组 洛谷P1083 借教室

    题目描述 在大学期间,经常需要租借教室.大到院系举办活动,小到学习小组自习讨论,都需要向学校申请借教室.教室的大小功能不同,借教室人的身份不同,借教室的手续也不一样. 面对海量租借教室的信息,我们自然 ...

  2. NOIP2012 洛谷P1083 借教室

    传送门 题意:有一些学(xian)生(quan)要借教室.在n天内,第i天学校有ri个教室.有m份订单,每份订单有三个数值dj,sj,tj,分别表示这个订单从第sj天开始到第tj天结束(包括端点),每 ...

  3. VIjos——V 1782 借教室 | | 洛谷——P1083 借教室

    https://vijos.org/p/1782|| https://www.luogu.org/problem/show?pid=1083 描述 在大学期间,经常需要租借教室.大到院系举办活动,小到 ...

  4. 洛谷P1083 借教室 题解

    题目 [NOIP2012 提高组] 借教室 题解 这道题是几周之前做到的一道题,本来不想讲的,因为这道题也是用到了二分答案的方法,这类题目之前已经发布过两篇题解了.但这道题还运用了差分数组这个思想,所 ...

  5. 洛谷P1083借教室题解

    题目 这个难度感觉并没有那么高,因为这个题暴力也好打,但是比较难想出正解,因为如果你不看标签是很难想到这个题竟然是二分,当然前缀和应该很好想,毕竟让你求的是在某段时间内借教室的和是否满足. 这样我们可 ...

  6. 洛谷P1083 借教室

    P1083 借教室 题目描述 在大学期间,经常需要租借教室.大到院系举办活动,小到学习小组自习讨论,都需要向学校申请借教室.教室的大小功能不同,借教室人的身份不同,借教室的手续也不一样. 面对海量租借 ...

  7. 洛谷 P1083 借教室【二分+差分/线段树】

    二分mid,然后用1~mid的操作在差分序列上加减,最后把差分序列前缀和起来,看是否有有超过初始r值的 #include<iostream> #include<cstdio> ...

  8. 『题解』洛谷P1083 借教室

    更好的阅读体验 Portal Portal1: Luogu Portal2: LibreOJ Portal3: Vijos Description 在大学期间,经常需要租借教室.大到院系举办活动,小到 ...

  9. 【题解】洛谷 P1083 借教室

    目录 题目 思路 \(Code\) 题目 P1083 借教室 思路 线段树.需要的操作为区间修改,区间查询.维护每个区间的最小值就好. \(Code\) #include<iostream> ...

  10. 洛谷 P1083 借教室 题解

    P1083 借教室 题目描述 在大学期间,经常需要租借教室.大到院系举办活动,小到学习小组自习讨论,都需要向学校申请借教室.教室的大小功能不同,借教室人的身份不同,借教室的手续也不一样. 面对海量租借 ...

随机推荐

  1. DataGrid 拖动 附加属性类

    项目需要实现一个DataGrid拖动排序,于是参考网上一些资源然后,修改了下实现了一个附加属性类,如下 使用方法 <DataGrid x:Name="shareGrid" t ...

  2. git添加本地仓库与远程仓库连接

    在本地建立一个文件夹,需要与远程git仓库进行连接,具体方法: <1>首先进入所在文件目录执行:  git init 初始化git,紧接着 git  add . git commit -m ...

  3. Jetty容器

    ♣Jetty和Tomcat的区别 ♣Jetty下载.安装 ♣eclipse安装jetty插件 ♣第一个jetty测试(maven+jetty) 1.Jetty和Tomcat的区别   Jetty 是一 ...

  4. POI导出EXCEL,浏览器不兼容,文件名称乱码,文件无法打开解决方法

  5. Freemarker的基本语法及入门基础

    freemarker的基本语法及入门基础一.freemarker模板文件(*.ftl)的基本组成部分        1. 文本:直接输出的内容部分        2. 注释:不会输出的内容,格式为&l ...

  6. springBoot之配置文件的读取以及过滤器和拦截器的使用

    前言 在之前的学习springBoot中,成功的实现了Restful风格的基本服务.但是想将之前的工程作为一个项目来说,那些是仅仅不够的.可能还需要获取自定义的配置以及添加过滤器和拦截器.至于为什么将 ...

  7. SpringMVC+FreeMarker实现静态资源文件自动添加版本号(md5)

    近日切换java开发,开始学习springframework.在实现静态资源文件自动计算版本号的实例时,因为不熟悉框架,走了不少弯路,好在最终解决了问题.这里写篇文章记录一下实现,也希望对大家有些用处 ...

  8. Android Stdio 如何自定义生成APK的名称

    Android Stdio自动默认生成的app的名称都是app-release或者app-debug,生成完后还要手动更改apk的名称,很是麻烦. 自定义生成APK的名称的方法:在\app\build ...

  9. STL中坑爹的max函数

    hdu1754永远难忘的痛,参数最好不要传耗时特别长的函数,因为会调用两次,如果是递归的话,不知道多少次呢.. 切记!切记!切记! 例如: //return max(getAns(root<&l ...

  10. kubernetes 命令使用

    学会命令的查找和使用,而不是死记命令,记命令不如提高英文水平 1.kubernetes环境搭建完成后,kubernetes环境搭建参考http://www.cnblogs.com/sosogengdo ...