散列--P1047 校门外的树
题目描述
某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米。我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置;数轴上的每个整数点,即0,1,2,…,L,都种有一棵树。
由于马路上有一些区域要用来建地铁。这些区域用它们在数轴上的起始点和终止点表示。已知任一区域的起始点和终止点的坐标都是整数,区域之间可能有重合的部分。现在要把这些区域中的树(包括区域端点处的两棵树)移走。你的任务是计算将这些树都移走后,马路上还有多少棵树。
输入输出格式
输入格式:
第一行有2个整数L(1≤L≤10000)和 M(1≤M≤100),L代表马路的长度,M代表区域的数目,L和M之间用一个空格隔开。
接下来的M行每行包含2个不同的整数,用一个空格隔开,表示一个区域的起始点和终止点的坐标。
输出格式:
1个整数,表示马路上剩余的树的数目。
输入输出样例

思路
本题主要解决数的重复问题,因为给的数据是一段一段的,我的第一想法是利用二维数组进行存储,之后去重。但是实施过程中,发现存在同一段重复被多次减去,出现问题。于是,可以设置一个数组变量用于记录树是否被标记,可以避免被重复标记的情况。题目的本质便是对输入数据的性质进行统计,存在两种性质的数据,标记的和未标记的,于是可以使用散列法
WA代码:
int nums[20000][2] ;
int main() {
int total, num;//马路长度,区域数
scanf("%d%d", &total, &num);
int signtrees = 0;//被标记需铲除的树的数量
//初始化
for (int i = 0; i < num; i++) {
scanf("%d%d", &nums[i][0], &nums[i][1]);
//被标记的树的个数
signtrees = nums[i][1] - nums[i][0] + signtrees + 1;
}
//去重
for (int i = 0; i < num; i++) {
//内层
for (int j = i+1; j < num; j++) {
//包含
if (nums[j][0] >= nums[i][0] && nums[j][1] <= nums[i][1]) {
signtrees = signtrees -(nums[j][1] - nums[j][0]+1);
} else //左入右出
if (nums[j][0] >= nums[i][0] && nums[j][0] <= nums[i][1]&& nums[j][1] > nums[i][1]) {
signtrees = signtrees -(nums[i][1] - nums[j][0]+1);
}else
//左出右入
if (nums[j][0] < nums[i][0] && nums[j][1] >= nums[i][0]&& nums[j][1] <= nums[i][1]) {
signtrees = signtrees - (nums[j][1] - nums[i][0]+1);
}else
if(nums[j][0]<nums[i][0]&&nums[j][1]>nums[i][1]){
signtrees = signtrees - (nums[i][1]-nums[i][0]+1);
}
}
}
printf("%d",total+1-signtrees);
return 0;
}
上面这段代码存在问题,假设num[1]={100,200},num[2]={150,200},num[3]={150,200},则num[2]与num[1]去重一次,则num[3]与num[1]去重一次,最后num[3]与num[2]去重一次,其多去重了一次,解决这个问题就需要为每个位置设定一个状态变量,0表示未被标记,1表示被去除
AC代码
#include <iostream>
#include <cstdio>
int sign[20000] = {0};//初始化全为被标记
using namespace std;
int main() {
int total, partnum, start, end;//马路长度,区域数,开始标记,结束标记
scanf("%d%d", &total, &partnum);
//初始化
for (int i = 0; i < partnum; i++) {
scanf("%d%d", &start, &end);
//标记已选
for (int j = start; j <= end; ++j) {
sign[j] = 1;
}
}
int result = 0;//拿出未被标记的树
for (int k = 0; k <= total; ++k) {
if (sign[k] == 0)
result++;
}
printf("%d", result);
return 0;
}
学到的点
还是散列的用法,输入的数作为数组的下标以用于统计数的性质
散列--P1047 校门外的树的更多相关文章
- P1047 校门外的树
P1047 校门外的树 题目描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0 ...
- 洛谷P1047 校门外的树
P1047 校门外的树 题目描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0 ...
- 洛谷——P1047 校门外的树
P1047 校门外的树 题目描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0 ...
- luogu P1047 校门外的树 x
P1047 校门外的树 题目描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0 ...
- 【洛谷】【线段树】P1047 校门外的树
[题目描述:] 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0,1,2,……,L ...
- [模拟]P1047 校门外的树
校门外的树 题目描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0,1,2,- ...
- 四重解法---P1047 校门外的树
题目描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0,1,2,--,L,都种 ...
- 洛谷 P1047 校门外的树(待完善)
链接:https://www.luogu.org/problemnew/show/P1047 题目: 题目描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是11米.我们可以把马路看 ...
- 洛谷题解P1047 校门外的树
题目描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0,1,2,…,L,都种有 ...
随机推荐
- 【bzoj2600】 [Ioi2011]ricehub
如果发现尾指针到头指针这段稻田的中位数上建一个粮仓时距离之和超过了B 就调整尾指针对距离维护一个前缀和 每次取中位数之后可以O(1)计算距离和 #include<algorithm> #i ...
- 【附论文】Facebook推面部识别软件 精准度高达97.25%
论文下载链接:http://pan.baidu.com/s/1gd86HXp 以下转载自36kr. 认脸对于人来说不是什么难事,除非是韩国小姐才需要最强大脑.但是计算机做同样的事情就要困难得多了.不过 ...
- 如何装载Storyboard中的ViewController?
如上图所示,如何装载Storyboard中指定的ViewController? 首先,需要指定ViewController的ID,如上图右上方红色方框内的Storyboard ID.然后使用下面的 ...
- easyui 生成tas方式
1.采用<a>标签形式 <div id="tabs" style="width:100%;"> <ul> <li id ...
- 【单独编译使用WebRTC的音频处理模块 - android】
更新 [2015年2月15日] Bill 这段时间没有再关注 WebRTC 以及音频处理的相关信息,且我个人早已不再推荐单独编译 WebRTC 中的各个模块出来使用.实际上本文的参考价值已经很小了,甚 ...
- Ruby实例方法和类方法的简写
创建: 2017/12/12 类方法 Sample.func 实例方法 Sample#func
- bzoj 1833: [ZJOI2010]count 数字计数【数位dp】
非典型数位dp 先预处理出f[i][j][k]表示从后往前第i位为j时k的个数,然后把答案转换为ans(r)-ans(l-1),用预处理出的f数组dp出f即可(可能也不是dp吧--) #include ...
- bzoj4720: [Noip2016]换教室(期望dp)
4720: [Noip2016]换教室 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 1294 Solved: 698[Submit][Status ...
- 10.23NOIP模拟题
叉叉题目描述现在有一个字符串,每个字母出现的次数均为偶数.接下来我们把第一次出现的字母 a 和第二次出现的 a 连一条线,第三次出现的和四次出现的字母 a 连一条线,第五次出现的和六次出现的字母 a ...
- [App Store Connect帮助]六、测试 Beta 版本(4.4) 管理 Beta 版构建版本:停止测试构建版本
在首页上,点按“我的 App”,选择您的 App,然后在工具栏中点按“TestFlight”. 在左列中的“构建版本”下,点按您 App 的平台(iOS 或 Apple TVOS). 在右表中,点按该 ...