题目描述

某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米。我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置;数轴上的每个整数点,即0,1,2,……,L,都种有一棵树。

由于马路上有一些区域要用来建地铁。这些区域用它们在数轴上的起始点和终止点表示。已知任一区域的起始点和终止点的坐标都是整数,区域之间可能有重合的部分。现在要把这些区域中的树(包括区域端点处的两棵树)移走。你的任务是计算将这些树都移走后,马路上还有多少棵树。

输入输出格式

输入格式:

输入文件tree.in的第一行有两个整数L(1 <= L <= 10000)和 M(1 <= M <= 100),L代表马路的长度,M代表区域的数目,L和M之间用一个空格隔开。接下来的M行每行包含两个不同的整数,用一个空格隔开,表示一个区域的起始点和终止点的坐标。

输出格式:

输出文件tree.out包括一行,这一行只包含一个整数,表示马路上剩余的树的数目。

输入输出样例

输入样例#1:

500 3

150 300

100 200

470 471

输出样例#1:

298

说明

NOIP2005普及组第二题

对于20%的数据,区域之间没有重合的部分;

对于其它的数据,区域之间有重合的情况。

分析

四种解法,不解释

#include<bits/stdc++.h>  //1层----模拟流
using namespace std;
int n,m,ans;
bool a[11000]; int read()
{
int x=0,f=1;char c=getchar();
while(!isdigit(c) && c!='-') c=getchar();
if(c=='-') f=-1,c=getchar();
while(isdigit(c)) x=x*10+c-'0',c=getchar();
return x*f;
} int main()
{
n=read()+1;m=read();
while(m--)
{
int l=read(),r=read();
for(int i=l;i<=r;++i)
a[i]=1; //表示已被砍
}
for(int i=0;i<=n;++i)
if(a[i]) ++ans; printf("%d\n",n-ans); return 0;
}

这里是分割线


#include<bits/stdc++.h>  //2层----忘了是什么算法来着,反正比模拟高级
using namespace std;
int n,m,ans;
int a[11000],f[11000]; int read()
{
int x=0,f=1;char c=getchar();
while(!isdigit(c) && c!='-') c=getchar();
if(c=='-') f=-1,c=getchar();
while(isdigit(c)) x=x*10+c-'0',c=getchar();
return x*f;
} int main()
{
n=read()+1;m=read(); //代码需要,就+1了,下同
while(m--)
{
int l=read()+1,r=read()+1;
++a[l];--a[r+1];
} for(int i=1;i<=n;++i)
{
f[i]=f[i-1]+a[i];
if(f[i]) ++ans; //被砍过,ans++
} printf("%d\n",n-ans); return 0;
}

这里是分割线


#include<bits/stdc++.h>  //3层----树状数组(比线段树好打一些)
using namespace std;
int n,m,f[11000],ans;
/* 本代码以树状数组区间加,单点查询为模板 */ int read()
{
int x=0,f=1;char c=getchar();
while(!isdigit(c) && c!='-') c=getchar();
if(c=='-') f=-1,c=getchar();
while(isdigit(c)) x=x*10+c-'0',c=getchar();
return x*f;
} int lowbit(int x)
{
return x&(-x);
} void update(int i,int x)
{
for(;i<=n;i+=lowbit(i))
f[i]+=x;
} bool query(int i)
{
int res=0;
for(;i;i-=lowbit(i))
if(f[i]) res+=f[i];
return res;
} int main()
{
n=read()+1;m=read(); //注意题目中的树范围是0~n,
//树状数组的操作是从1开始的,所以n++
while(m--)
{
int l=read()+1,r=read()+1; //同上+1
update(l,1);
update(r+1,-1);
} for(int i=1;i<=n;++i)
if(query(i)) ++ans; //被砍过,ans++ printf("%d\n",n-ans); return 0;
}

这里是分割线


#include<bits/stdc++.h>  //4层----线段树
using namespace std;
int n,m,sum[41000]; //姑且写个读入优化吧,虽说其实用不着
int read()
{
int x=0,f=1;char c=getchar();
while(!isdigit(c) && c!='-') c=getchar();
if(c=='-') f=-1,c=getchar();
while(isdigit(c)) x=x*10+c-'0',c=getchar();
return x*f;
} void buildtree(int k,int l,int r)
{
if(l==r){ sum[k]=1; return ;}
if(l>r) return ;
int mid=l+r>>1;
buildtree(k*2,l,mid);
buildtree(k*2+1,mid+1,r);
sum[k]=sum[k*2]+sum[k*2+1];
} void update(int k,int l,int r,int L,int R)
{
if(l>R || r<L || !sum[k]) return ; //不包含直接退
if(L<=l && r<=R) //全包含sum改0
{
sum[k]=0;
return ;
} int mid=l+r>>1;
update(k*2,l,mid,L,R);
update(k*2+1,mid+1,r,L,R);
sum[k]=sum[k*2]+sum[k*2+1]; //更新sum[father];
} int main()
{
n=read();m=read();
buildtree(1,0,n);
while(m--)
{
int l,r;
l=read();r=read();
update(1,0,n,l,r);
} printf("%d\n",sum[1]);
return 0;
}
                                                            --all by Mr Zhang

ok,四种解法发完。

(你会几种?_ (:зゝ∠) _)

测试平台

落谷P1047

四重解法---P1047 校门外的树的更多相关文章

  1. P1047 校门外的树

    P1047 校门外的树 题目描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0 ...

  2. 洛谷P1047 校门外的树

    P1047 校门外的树 题目描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0 ...

  3. 洛谷——P1047 校门外的树

    P1047 校门外的树 题目描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0 ...

  4. luogu P1047 校门外的树 x

    P1047 校门外的树 题目描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0 ...

  5. 【洛谷】【线段树】P1047 校门外的树

    [题目描述:] 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0,1,2,……,L ...

  6. [模拟]P1047 校门外的树

    校门外的树 题目描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0,1,2,- ...

  7. 洛谷 P1047 校门外的树(待完善)

    链接:https://www.luogu.org/problemnew/show/P1047 题目: 题目描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是11米.我们可以把马路看 ...

  8. 洛谷题解P1047 校门外的树

    题目描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0,1,2,…,L,都种有 ...

  9. [线段树]P1047 校门外的树

    题目描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0,1,2,……,L,都种 ...

随机推荐

  1. js异步下载文件请求

    注意 :通常下载文件是用get请求 window.location.href=url; 但是 我们需要下载完成监听,所以必须要异步执行.用常规的ajax是不可以的.我们要用blob对象来实现1.原生的 ...

  2. [NIO-2]通道和FileChannel

    通道是什么 通道式(Channel)是java.nio的第二个主要创新.通道既不是一个扩展也不是一项增强,而是全新的.极好的Java I/O示例,提供与I/O服务的直接连接.Channel用于在字节缓 ...

  3. 【1】【leetcode-33,81】 搜索旋转排序数组

    (没思路) 33. 搜索旋转排序数组 假设按照升序排序的数组在预先未知的某个点上进行了旋转. ( 例如,数组 [0,1,2,4,5,6,7] 可能变为 [4,5,6,7,0,1,2] ). 搜索一个给 ...

  4. Docker 从入门到放弃(二)容器使用

    Docker 容器使用 一.Docker 客户端 docker 客户端非常简单 ,我们可以直接输入 docker 命令来查看到 Docker 客户端的所有命令选项. root@iZ235mi4a64Z ...

  5. Immunity Debugger学习 二

    1.Exploit开发 发现漏洞只是一个开始,在你完成利用程序之前,还有很长一段路要走.不过Immunity专门为了这项任务做了许多专门设计,相信能帮你减少不少痛苦.接下来我们开发一些PyComman ...

  6. 利用PHP连接数据库——实现用户登录注册功能以及管理员对用户注册的审核功能

    1.用户注册页面 页面效果: 代码如下: <!DOCTYPE html><html>    <head>        <meta charset=" ...

  7. MVC 自定义路由

    RouteConfig.cs 代码如下: public class RouteConfig { public static void RegisterRoutes(RouteCollection ro ...

  8. UE4源码笔记

    找编辑器LOG,找相应代码.(改相应LOG 重编译后有反应)GenerateProjectFiles  寻找配置,生成VS文件.  有一些小工具项目默认是没打开的.API宏是较旧的代码,新的代码会设计 ...

  9. xtrabackup 在线主从搭建

    因为意外导致某个MySQL的从服务器宕机,且不可修复,因为是业务数据库,不能停机和锁表进行从库的搭建,所以考虑了使用xtrabackup 进行在线主从搭建. 一.数据库环境 注意:  主从搭建主库一定 ...

  10. java乱码解决方法

    String name = request.getParameter("name"); 乱码解决:String name = new String(request.getParam ...