丽娃河的狼人传说

Time limit per test: 1.0 seconds

Time limit all tests: 1.0 seconds

Memory limit:  megabytes

丽娃河是华师大著名的风景线。但由于学校财政紧缺,丽娃河边的路灯年久失修,一到晚上就会出现走在河边要打着手电的情况,不仅非常不方便,而且影响安全:已经发生了大大小小的事故多起。

方便起见,丽娃河可以看成是从  到 n 的一条数轴。为了美观,路灯只能安装在整数点上,每个整数点只能安装一盏路灯。经专业勘测,有 m 个区间特别容易发生事故,所以至少要安装一定数量的路灯,

请问至少还要安装多少路灯。
Input 第一行一个整数 T (≤T≤),表示测试数据组数。 对于每组数据: 第一行三个整数 n,m,k (≤n≤,≤m≤,≤k≤n)。 第二行 k 个不同的整数用空格隔开,表示这些位置一开始就有路灯。 接下来 m 行表示约束条件。第 i 行三个整数 li,ri,ti 表示:第 i 个区间 [li,ri] 至少要安装 ti 盏路灯 (≤li≤ri≤n,≤ti≤n)。 Output 对于每组数据,输出 Case x: y。其中 x 表示测试数据编号(从 开始),y 表示至少要安装的路灯数目。如果无解,y 为 −。
Examples
Input Output Case :
Case :
Case : Note 因为今天不是满月,所以狼人没有出现。
Source
华东师范大学网赛 /**
题目:Problem #3263 丽娃河的狼人传说
链接:http://acm.ecnu.edu.cn/problem/3263/
题意:给定一个数n,表示一个1-n的数轴,给定一个k,表示数轴上k个位置已经安装了灯。给定一个m,表示有m个区间[l,r],
每个区间后面有个整数值表示在这个区间至少要有多少盏灯。l,r都是整数。灯只可以安装在数轴的整数点上。
问至少要安装多少盏灯,才能使所有区间都满足自己要求的条件。如果无解,输出-1. 思路:贪心,对r进行排序即可。 */ #include<bits/stdc++.h>
using namespace std;
typedef long long LL;
typedef pair<int,int> P;
const int maxn = 1e5+;
int T, n, m, k;
int lgt[];
struct node
{
int l, r, t;
bool operator < (const node&k)const {
return r<k.r;
}
}a[];
int main()
{
cin>>T;
int cas = ;
while(T--)
{
scanf("%d%d%d",&n,&m,&k);
memset(lgt, , sizeof lgt);
for(int i = ; i <= k; i++){
int x;
scanf("%d",&x);
lgt[x] = ;
}
int flag = ;
for(int i = ; i < m; i++){
scanf("%d%d%d",&a[i].l,&a[i].r,&a[i].t);
if(a[i].r-a[i].l+<a[i].t){flag = ;}
}
if(flag){
printf("Case %d: -1\n",cas++) ; continue;
}
sort(a,a+m);
int ans = ;
for(int i = ; i < m; i++){
int l = a[i].l, r = a[i].r;
int cnt = ;
for(int j = l; j <= r; j++){
cnt += lgt[j];
}
if(cnt>=a[i].t) continue;
cnt = a[i].t-cnt;
for(int j = r; j >= l&&cnt; j--){
if(lgt[j]==){
lgt[j] = ; cnt--;
ans ++;
}
}
}
printf("Case %d: %d\n",cas++,ans);
}
return ;
}

Problem #3263 丽娃河的狼人传说 区间满足灯数,r排序后贪心。的更多相关文章

  1. ECNU 3263 丽娃河的狼人传说(差分约束)

    丽娃河的狼人传说 Time limit per test: 1.0 seconds Memory limit: 256 megabytes 丽娃河是华师大著名的风景线.但由于学校财政紧缺,丽娃河边的路 ...

  2. ECNU 3263 - 丽娃河的狼人传说

    一定要纪念一下第一道在比赛中自己做出来的贪心. 题目链接:http://acm.ecnu.edu.cn/problem/3263/ Time limit per test: 1.0 seconds T ...

  3. ECNU 3263 丽娃河的狼人传说 (贪心)

    链接:http://acm.ecnu.edu.cn/problem/3263/ 题意: 从 1 到 n 的一条数轴.有 m 个区间至少要安装一定数量的路灯,路灯只能装在整数点上,有k盏路灯已经安装好  ...

  4. EOJ 3263 丽娃河的狼人传说

    差分约束系统,$spfa$. 首先判断无解,若某个约束的$t$大于区间长度,则一定无解. 否则一定有解,可以得到一系列的不等式: 最终区间和大于等于目前的区间和:$S[R]-S[L-1]≥val$, ...

  5. EOJ3263:丽娃河的狼人传说(贪心)

    传送门 题意 分析 考虑将区间按右端点排序,再遍历区间,操作即可 建议以加方式写 trick 1.不需要判区间重合 代码 #include<cstdio> #include<cstr ...

  6. POJ 3468 A Simple Problem with Integers(线段树功能:区间加减区间求和)

    题目链接:http://poj.org/problem?id=3468 A Simple Problem with Integers Time Limit: 5000MS   Memory Limit ...

  7. POJ 3468 A Simple Problem with Integers(线段树 成段增减+区间求和)

    A Simple Problem with Integers [题目链接]A Simple Problem with Integers [题目类型]线段树 成段增减+区间求和 &题解: 线段树 ...

  8. (hdu step 7.1.2)You can Solve a Geometry Problem too(乞讨n条线段,相交两者之间的段数)

    称号: You can Solve a Geometry Problem too Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/ ...

  9. Problem after converting keras model into Tensorflow pb - 将keras模型转换为Tensorflow pb后的问题

    I'm using keras 2.1.* with tensorflow 1.13.* backend. I save my model during training with .h5 forma ...

随机推荐

  1. Android Studio 首次安装取消自动下载SDK

    一.第一次安装: Android Studio安装完成后,第一次启动AS前,为了避免重新下载新版本的SDK,需要做如下操作: AS启动前,打开安装目录,请先将bin目录的idea.properties ...

  2. centos 7.3systemctl工具

    http://www.cnblogs.com/tswcypy/p/4479153.html

  3. 理解SQL原理,写出高效代码

    做软件开发的,大部分人都离不开跟数据库打交道,特别是erp开发的,跟数据库打交道更是频繁,存储过程动不动就是上千行,数据量大,人员流动大,那么我们还能保证下一段时间系统还能流畅的运行吗?我们还能保证下 ...

  4. 重设Windows 7密码 z

    Restart the computer to boot using the CD. Once the GUI loads, press SHIFT+F10 to bring up the comma ...

  5. java.sql.SQLException: Io 异常: Got minus one from a read call

    博客分类: Oracle   Tomcat服务器下的应用连接Oracle时报错,出现以下异常: java.sql.SQLException: Io 异常: Got minus one from a r ...

  6. 微信php分享页面自定义标题与内容

    1.因为现在分享页面,发给朋友或者朋友圈都没办法自定义标题.图片和内容,所以必须要有微信公众号 2.如果有微信公众号可直接登录,如果没有要注册,注册完或者登录了 3.查看你的权限,左侧最下面开发的接口 ...

  7. 关于 modelNameLike 查询无数据

    ---恢复内容开始--- 1.今天在测试的时候发现 model中的name不能模糊查询. ModelQuery modelQuery = repositoryService.createModelQu ...

  8. linux & windows 共享 smbd 部署

    smbd  : yum install samba samba-client samba-swat mount.cifs :  yum -y install cifs-utils  ##挂载nas 文 ...

  9. kettle新手教程

     1.kettle介绍 kettle是一个ETL(Extract, Transform and Load抽取.转换.加载)工具,ETL工具在数据仓库项目使用很频繁,kettle也能够应用在下面一些 ...

  10. ubuntu16.04 登录密码破解方法

    1:开机按Shift键,出现如下界面.(手速要快,Shift键要按时间久一点) 选择第二项 2:按回车键进入如下界面,然后选中有recovery mode的选项(第三项) 3:按e进入如下界面,并找到 ...