牛客练习赛 26 C题 城市规划【贪心】
<题目链接>
题目描述
输入描述:
第一行两个整数n, m,分别表示城市的数量和请求的数量
接下来m行,每行两个整数x,y,表示需要使得x不能到达y
输出描述:
输出一个整数,表示最小断开桥的数量
输入
4 2
1 3
2 4
输出
1
说明
可以断开(2, 3)城市之间的道路
输入
4 3
1 3
2 4
1 2
输出
2
说明
可以断开(1, 2) (2, 3)之间的道路
备注:
对于100%的数据:n ≤ 106, m ≤ 107 本题不卡常数,请设计严格线性做法
读入文件较大,请使用读入优化,本机调试时请使用文件输入输出
#define getchar() (p1 == p2 && (p2 = (p1 = buf) + fread(buf, 1, 1<<22, stdin), p1 == p2) ? EOF : *p1++)
char buf[(1 << 22)], *p1 = buf, *p2 = buf;
inline int read() {
char c = getchar(); int x = 0, f = 1;
while(c < '0' || c > '9') {if(c == '-') f = -1; c = getchar();}
while(c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
return x * f;
}
用法:
int a = read(), b = read();
std::cout << a + b;
由于nowcoder的编译器限制,如果需要在程序中开107级别的数组,可能会出现内存超限的情况,请使用new函数手动申请用法:int* P = new int[(int)1e7 + 10]; 解题分析:
其实就是贪心,刚开始还以为和最大匹配有关,就是找出每个需要有缺口的区间,按左端点的顺序遍历,维护这些区间的交集(记录下这个交集区间的最小右端点即可),给这些区间的交集分配一个缺口,对于新加入的区间,如果该区间与前面的区间无交集即新加入区间的左端点>=之前记录的交集区间的右端点,那么就要给这个新开辟出来的交集区间分配一个缺口。
#include<bits/stdc++.h>
using namespace std;
const int N=1e6+;
#define INF 0x3f3f3f3f #define getchar() (p1 == p2 && (p2 = (p1 = buf) + fread(buf, 1, 1<<22, stdin), p1 == p2) ? EOF : *p1++)
char buf[( << )], *p1 = buf, *p2 = buf; inline int read(){ //读入优化
char c = getchar(); int x = , f = ;
while(c < '' || c > '') {if(c == '-') f = -; c = getchar();} //读入符号
while(c >= '' && c <= '') x = x * + c - '', c = getchar(); //读入数字
return x * f;
} int res,seg[N],n,m; int main()
{
n=read();
m=read();
for(int i=;i<=n;i++) seg[i]=INF;
for(int i=,l,r;i<=m;i++)
{
l=read();
r=read();
if(l>r)swap(l,r); //这一步不要忘记
seg[l]=min(seg[l],r); //当前左端点的最小值,因为同一个左端点,可能会有好几个右端点与置对应,所以只需要记录最小的右端点就够了
} int cal=;
for(int i=;i<=n;i++)
{
if(seg[i]==INF)continue; //如果无穷大 ,说明没有存在以i为左端点的线段,使得这段线段之间要有一个缺口
if(i>=cal){ //如果线段的左端点大于最小的右端点,说明这里需要再次断开一次,至于为什么是>=,因为断开的线段是在(l,r),这个开区间中
res++;
cal=seg[i]; //更新最小右端点
}
else cal=min(cal,seg[i]); //否则更新最小右端点 //上面两步更新相当于想将需要断开的区域尽可能的求交集,使得需要断开的次数最小
}
printf("%d",res);
return ;
}
2018-09-08
牛客练习赛 26 C题 城市规划【贪心】的更多相关文章
- 牛客练习赛 26 B题 烟花【DP】(经典)
<题目链接> 题目描述 小a有个烟花,每个烟花代表着互不相同的颜色,对于第个烟花,它有的概率点燃,现在小a要去点燃它们,他想知道产生颜色的期望个数 及 产生恰好产生种颜色的概率 输入描述: ...
- 牛客练习赛26:D-xor序列(线性基)
链接:牛客练习赛26:D-xor序列(线性基) 题意:小a有n个数,他提出了一个很有意思的问题:他想知道对于任意的x, y,能否将x与这n个数中的任意多个数异或任意多次后变为y 题解:线性基 #inc ...
- 牛客练习赛44 B题 (思维)
链接:https://ac.nowcoder.com/acm/contest/634/B 来源:牛客网 给出n条线段,第i条线段的长度为ai, 每次可以从第i条线段的j位置跳到第i + 1条线段的j+ ...
- 牛客练习赛26 E-树上路径 (树链剖分+线段树)
链接:https://ac.nowcoder.com/acm/contest/180/E 来源:牛客网 树上路径 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/C++ 262144K,其他语 ...
- 牛客练习赛26 D xor序列 (线性基)
链接:https://ac.nowcoder.com/acm/contest/180/D 来源:牛客网 xor序列 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他 ...
- 牛客练习赛38 D 题 出题人的手环 (离散化+树状数组求逆序对+前缀和)
链接:https://ac.nowcoder.com/acm/contest/358/D来源:牛客网 出题人的手环 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 524288K,其他 ...
- 牛客练习赛32 B题 Xor Path
链接:https://ac.nowcoder.com/acm/contest/272/B来源:牛客网 题目描述 给定一棵n个点的树,每个点有权值.定义表示 到 的最短路径上,所有点的点权异或和. ...
- 牛客练习赛51 D题
链接:https://ac.nowcoder.com/acm/contest/1083/D来源:牛客网 有一个草原可以用一个1~400的数轴表示.有n头羊和q个查询.每头羊的编号分别是1,2,3…n. ...
- 牛客练习赛26—D xor序列 —线性基
这是我第一次写关于线性基的题目.其实这题很好理解,先把给出的数能异或出的值给存在p数组里面,p[i]代表着该异或出的数的最高位为第i位且为1. 求出来后,再把x,y处理下,然后直接一位一位的判断是否为 ...
随机推荐
- ios 调整 label 的字体行间距
UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(0, 100, self.view.frame.size.width, 200) ...
- Confluence 6 数据库字符集编码和问题
数据库字符集编码 你的数据库和 JDBC 数据源连接必须配置为使用 UTF-8 编码(或者根据你配置的数据库来制定正确的 UTF-8 编码字符集,例如在 Oracle 中使用的是 AL32UTF8 ) ...
- Confluence 6 找到你的支持识别代码(SEN)
你可以在下面 3 个地方找到你的 SEN 代码: 在 Confluence 中,进入 > 基本配置(General Configuration) > 许可证详细(License Deta ...
- Confluence 6 你模板中可用的对象
包含宏正文和参数,下面的 Confluence 对象在宏中可用: $body 宏的正文(如果宏有正文的话) String $paramfoo, $parambar, ...$param<name ...
- eclipse c++11 cmake gnuradio
承接之前的脚本.修改一下这个脚本的代码就可以让eclipse使用C++11了 #!/bin/sh echo "creat_debug for sdk" echo "mkd ...
- java多线程快速入门(十七)
多线程通讯实例(必须要有多个线程.必须要管理同一个变量:线程A生产一个变量,线程B消费一个变量) package com.cppdy; class User { public String usern ...
- Zookeeper安装(本地,伪分布式,集群)
概述 ZooKeeper是一个分布式开源框架,提供了协调分布式应用的基本服务,它向外部应用暴露一组通用服务——分布式同步(Distributed Synchronization).命名服务(Namin ...
- Brup Suite 渗透测试笔记(七)
继续接上次笔记: 1.Burp Intruder的payload类型的子模块(Character blocks)使用一种给出的输入字符,根据指定的设置产生指定大小的字符块,表现形式为生成指定长度的字符 ...
- RabbitMQ在java中基础使用
RabbitMQ相关术语: 1.Broker:简单来说就是消息队列服务器实体. 2.Exchange:消息交换机,它指定消息按什么规则,路由到哪个队列. ...
- 如何使用VisualSVN Server建立版本库
首先打开VisualSVN Server Manager,如图: 可以在窗口的右边看到版本库的一些信息,比如状态,日志,用户认证,版本库等.要建立版本库,需要右键单击左边窗口的Repositores, ...