Luogu 3626 [APIO2009]会议中心

很优美的解法。

推荐大佬博客

如果没有保证字典序最小这一个要求,这题就是一个水题了,但是要保证字典序最小,然后我就不会了……

如果一条线段能放入一个区间$[l', r']$并且不影响最优答案,那么对于这条线段$[l, r]$,设$solve(l, r)$表示$[l, r]$这个区间里面最多能放多少条线段,一定要有条件$solve(l', l - 1) + solve(r + 1, r') + 1 == solve(l', r')$。

那么贪心的时候顺便考虑一下怎么检验的问题就可以了,如果暴力检验是$O(n)$的,考虑优化,利用一下倍增思想,我们设$f_{i, j}$表示从$i$开始选择$2^{j}$条线段所能到达的最靠左的右端点,那么在离散化之后就可以用$O(nlogn)$的时间预处理出$f$数组,这样子每一次检验求$solve$的时间是$O(logn)$的,具体怎么处理可以参照下面的代码。

考虑一下最后怎么进行的贪心,对于每一条线段,我们检验一下是不是能放,这个检验的过程可以用很多数据结构做到$O(logn)$,如果能放入,我们就找出之前放过的最前的右端点和最后的左端点,然后chk一下上面的条件是否成立就可以了。

感觉这个过程写个线段树更直观一点,还是学习了一下上面那位大佬高能的树状数组写法。

时间复杂度$O(nlogn)$。

Code:

#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;const int N = 2e5 + 5;
const int Lg = 20;
const int inf = 1 << 30;int n, tot = 0, maxn = 0;
int l[N], r[N], f[N << 1][Lg];
int ans[N], lmax[N << 1], rmax[N << 1], lsum[N << 1], rsum[N << 1];struct Innum {int val, id;
} in[N << 1];bool cmpIn(const Innum &x, const Innum &y) {if(x.val != y.val) return x.val < y.val;else return x.id < y.id;
}inline void read(int &X) {X = 0; char ch = 0; int op = 1;for(; ch > '9'|| ch < '0'; ch = getchar())if(ch == '-') op = -1;for(; ch >= '0' && ch <= '9'; ch = getchar())X = (X << 3) + (X << 1) + ch - 48;X *= op;
}inline int max(int x, int y) {return x > y ? x : y;
}inline int min(int x, int y) {return x > y ? y : x;
}inline void chkMax(int &x, int y) {if(y > x) x = y;
}inline void discrete() {sort(in + 1, in + 1 + tot, cmpIn);for(int cnt = 0, i = 1; i <= tot; i++) {if(in[i].val != in[i - 1].val) ++cnt;maxn = max(maxn, cnt);if(in[i].id > n) r[in[i].id - n] = cnt;else l[in[i].id] = cnt;}
}#define lowbit(x) ((x) & (-x))inline void aSum(int *now, int x) {for(; x <= maxn; x += lowbit(x))++now[x];
}inline int qSum(int *now, int x) {int res = 0;for(; x > 0; x -= lowbit(x))res += now[x];return res;
}inline void aMax(int *now, int x) {for(int t = x; x <= maxn; x += lowbit(x))chkMax(now[x], t);
}inline int qMax(int *now, int x) {int res = 0;for(; x > 0; x -= lowbit(x))chkMax(res, now[x]);return res;
}inline int solve(int ln, int rn) {int res = 0;for(int i = 18; i >= 0; i--)if(f[ln][i] <= rn) res += (1 << i), ln = f[ln][i] + 1;return res;
}int main() {read(n);for(int i = 1; i <= n; i++) {read(l[i]), read(r[i]);in[++tot] = (Innum) {l[i], i};in[++tot] = (Innum) {r[i], i + n};}discrete();memset(f, 0x7f, sizeof(f));for(int i = 1; i <= n; i++)f[l[i]][0] = min(f[l[i]][0], r[i]);for(int i = maxn; i >= 1; i--) {f[i][0] = min(f[i][0], f[i + 1][0]);for(int j = 1; f[i][j - 1] <= maxn && (1 << j) <= n; j++)f[i][j] = f[f[i][j - 1] + 1][j - 1];} /*  for(int i = 1; i <= maxn; i++)printf("%d ", f[i][0]);printf("\n");   *//*  for(int i = 1; i <= n; i++)printf("%d %d\n", l[i], r[i]);printf("\n");   */tot = 0;for(int i = 1; i <= n; i++) {int v = tot - qSum(rsum, l[i] - 1) - qSum(lsum, maxn - r[i]);if(v > 0) continue;int lst = qMax(rmax, l[i] - 1), nxt = maxn - qMax(lmax, maxn - r[i]);if(solve(lst + 1, l[i] - 1) + solve(r[i] + 1, nxt) + 1 == solve(lst + 1, nxt)) {ans[++tot] = i;aSum(rsum, r[i]), aSum(lsum, maxn - l[i] + 1);aMax(rmax, r[i]), aMax(lmax, maxn - l[i] + 1);}//        printf("%d ", v);
    }
//    printf("\n");
printf("%d\n", tot);for(int i = 1; i <= tot; i++)printf("%d ", ans[i]);printf("\n");return 0;   
}
View Code

转载于:https://www.cnblogs.com/CzxingcHen/p/9553116.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/365938.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python编程求导数_面向对象编程 —— java实现函数求导

首先声明一点&#xff0c;本文主要介绍的是面向对象&#xff08;OO&#xff09;的思想&#xff0c;顺便谈下函数式编程&#xff0c;而不是教你如何准确地、科学地用java求出函数在一点的导数。 一、引子 defd(f) :defcalc(x) : dx 0.000001 #表示无穷小的Δx return (f(xdx) - …

listitem android,android-为contextmenu标识listitem的ID

我有一个扩展活动的视图. ListView将显示许多列表项.当用户长按时,我想向他们显示一个上下文菜单,允许他们选择编辑,删除等…,然后标识被选为要执行操作的项目的列表项.在onCreate中,我有&#xff1a;listView.setAdapter(adapter);listView.setOnItemClickListener(onListClic…

JUnit理论简介

您读过数学理论吗&#xff1f; 它通常读取如下内容&#xff1a; 对于所有a&#xff0c;b> 0满足以下条件&#xff1a;a b> a和a b> b 通常&#xff0c;这些语句更难以理解。 这种陈述有一些有趣之处&#xff1a;它适用于相当大&#xff08;在这种情况下为无限&a…

基础类

/*_________________________基础类 构造&#xff1a;独立 原型&#xff1a;共享设计人&#xff1a;杨秀徐 2013-8-1_________________________*///1、结构(function (i) { //参数作为对外暴露的对象var o { }; //对象直接量、实例…

BZOJ5093图的价值(斯特林数)

题目描述 “简单无向图”是指无重边、无自环的无向图&#xff08;不一定连通&#xff09;。一个带标号的图的价值定义为每个点度数的k次方的和。给定n和k&#xff0c;请计算所有n个点的带标号的简单无向图的价值之和。因为答案很大&#xff0c;请对998244353取模输出。题解因为…

重写override

不可重写私有方法。 不可重写非静态的方法&#xff0c;虽然编译器不会报错&#xff0c;但是得不到预期的结果。 可以通过重写的形式对父类的功能进行重新定义&#xff0c;比如&#xff1a;对功能进行修改或者进行升级时。 class BaseAction {public void showMsg(){System.out.…

python程序写诗_用Python作诗,生活仍有诗和远方

原标题&#xff1a;用Python作诗&#xff0c;生活仍有诗和远方 报 名 来源&#xff1a;TheodoreXu链接&#xff1a; https://segmentfault.com/a/1190000013154329 常听说&#xff0c;现在的代码&#xff0c;就和唐朝的诗一样重要。 可对我们来说&#xff0c;写几行代码没什么&…

华为鸿蒙手机beta版,鸿蒙2.0 Beta手机版来了!明年将全面支持华为手机

读创/深圳商报记者陈 姝备受关注的华为鸿蒙操作系统(HarmonyOS&#xff0c;以下简称鸿蒙)有了新进展。华为消费者业务软件部总裁王成录日前透露&#xff0c;将于12月16日在北京发布鸿蒙2.0手机开发者Beta版本。王成录在12月14日发微博称&#xff1a;“HarmonyOS正沿着我们在HDC…

Spring LDAP 2.0.0发布

Spring团队很高兴宣布Spring LDAP 2.0.0已发布&#xff0c;并且现在可以从Maven Central和Bintray获得。 Spring LDAP 2.0.0.RELEASE Released列出了新发行版中的所有更改。 JIRA的更改日志也包含更改列表。 以下介绍了2.0.0版本的最基本功能&#xff1a; Spring LDAP现在包括…

Django 路由层

Django的下载与基本命令 下载Django&#xff1a;pip3 install django2.0.1创建一个django project: django-admin startproject luffy在mysite目录下创建应用&#xff1a;python manage.py startapp app01启动django项目:python manage.py runserver 8080 我们访问&#xff1a;…

seajs-require使用示例

<script type"text/javascript">define([js/b],[],function(require) {//定义B模块,id为js/bvar o{b: B模块};return o; })define([js/a],[],function(require) {//定义a模块var o{a: require(js/b)//引用js/b模块id&#xff0c;而不是文件};return o; })seajs…

caffe安装_目标检测之caffe-ssd模型训练与测试

最近把一个ssd网络的net..prototxt网络结构和自己生成的hdf5格式数据一起做训练时发现经常报错&#xff0c;因为ssd中一些层在caffe中并没有实现&#xff0c;需要自己写相应的.cpp,.cu文件重新编译&#xff0c;比较麻烦&#xff0c;而大家通常训练caffe-ssd都是基于原作者公开的…

Python之classmethod和staticmethod的区别

python中3种方式定义类方法&#xff0c;常规方式、classmethod修饰方式、staticmethod修饰方式。 class A(object):def foo(self, x):print(调用foo函数 (%s, %s)%(self, x))print(self:, self)classmethoddef class_foo(cls, x):print(调用class_foo函数 (%s, %s) % (cls, x))…

android 字符串反转,Golang之字符串操作(反转中英文字符串)

//字符串反转package mainimport "fmt"func reverse(str string) string {var result stringstrLen : len(str)for i : ; i < strLen; i {result result fmt.Sprintf("%c", str[strLen-i-])}return result}func reverse1(str string) string {var res…

Spring Integration Publisher

考虑一个假设的要求–您的应用程序中有一个服务类&#xff0c;并且想要捕获有关此服务调用的一些信息&#xff1a; Service public class SampleBean {private static final Logger logger LoggerFactory.getLogger(SampleBean.class);public Response call(Request request)…

POJ - 1125(Stockbroker Grapevine)

Stockbroker Grapevine 题目链接&#xff1a; http://poj.org/problem?id1125 题目&#xff1a; Time Limit: 1000MS Memory Limit: 10000KTotal Submissions: 39459 Accepted: 22024Description Stockbrokers are known to overreact to rumours. You have been contracted t…

php开发微信图灵机器人

本着开源为原则&#xff0c;为这个世界更美好作出一份共享&#xff0c;我就给大家做个指路人&#xff0c;如果实用&#xff0c;记得给提供开源的朋友一些鼓励。 简单介绍一下实现思路&#xff0c;使用swoole扩展接管php运行&#xff0c;由于swoole只能在类UNIX上运行&#xff0…

jQuery源码的基础知识

序言&#xff1a;DOM addEventListener attachEvent与addEventListener区别适应的浏览器版本不同&#xff0c;同时在使用的过程中要注意attachEvent方法 按钮onclickaddEventListener方法 按钮click一、arguments对象&#xff1a; 1、arguments 属性 为当前执行…

python如何读取数据并输出为表格_Python实现将数据库一键导出为Excel表格的实例...

数据库数据导出为excel表格&#xff0c;也可以说是一个很常用的功能了。毕竟不是任何人都懂数据库操作语句的。 下面先来看看完成的效果吧。 数据源导出结果依赖 由于是Python实现的&#xff0c;所以需要有Python环境的支持 Python2.7.11 我的Python环境是2.7.11。虽然你用的可…

android手机连接无线路由器上网设置,手机连接无线网络怎么设置?手机Wifi无线网设置教程...

随着智能手机无线上网的流行&#xff0c;如今很多家庭都会组建Wifi无线网络&#xff0c;目前组建Wifi网络&#xff0c;大致有两种情况&#xff0c;一种是使用无线路由器&#xff0c;另外一种是将笔记本变身无线无路由器&#xff0c;从而实现智能手机也可以免费Wifi上网&#xf…