P2418 yyy loves OI IV
题目背景
某校2015届有两位OI神牛,yyy和c01。
题目描述
全校除他们以外的N名学生,每人都会膜拜他们中的某一个人。现在老师要给他们分宿舍了。但是,问题来了:
同一间宿舍里的人要么膜拜同一位大牛,要么膜拜yyy和c01的人数的差的绝对值不超过M。否则他们就会打起来。
为了方便,老师让N名学生站成一排,只有连续地站在一起的人才能分进同一个宿舍。
假设每间宿舍能容纳任意多的人,请问最少要安排几个宿舍?
输入输出格式
输入格式:
第一行,两个正整数N和M
第2……N+1行,每行一个整数1或2,第i行的数字表示从左往右数第i-1个人膜拜的大牛。
1表示yyy,2表示c01.
输出格式:
一行,一个整数,表示最少要安排几个宿舍。
输入输出样例
输入样例#1: 复制
5 1
1
1
2
2
1
输出样例#1: 复制
1
说明
难度题,做好心理准备~
测试点编号 N的范围 M的范围
1~3 <=2,500 <=10
4~5 <=500,000 <=10
6~10 <=500,000 <=2,000
\(define\) 了\(min\)和\(max\)然后惊喜的发现我\(10000\)的数据

emmm...简单形容就是我的线段树被\(n^2\)暴力踩爆了QAQ
思路很好想啊
维护前缀和线段树区间查询可行区间和最远路径相同前驱取min值即可
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#define LL long long
#define update(now) d[now]=min(d[now*2],d[now*2+1])
using namespace std;
int i,m,n,j,k,d[5000001],f[5000001],x[1000001],las,wz;
int ask(int now,int l,int r,int ll,int rr)
{
if(l>=ll && r<=rr) return d[now];
int mid=(l+r)>>1,ans=0x3f3f3f;
if(ll<=mid) ans=min(ans, ask(now*2,l,mid,ll,rr));
if(rr>mid) ans=min(ans, ask(now*2+1,mid+1,r,ll,rr));
return ans;
}
void modify(int now,int l,int r,int z,int w)
{
if(l==r) {d[now]=min(d[now],z); return;}
int mid=(l+r)>>1;
if(w<=mid) modify(now*2,l,mid,z,w);
if(w>mid) modify(now*2+1,mid+1,r,z,w);
update(now);
}
int main()
{
freopen("in.txt","r",stdin);
memset(d,0x3f,sizeof(d));
memset(x,0x3f,sizeof(x));
scanf("%d%d",&n,&m);
modify(1,0,2*n,0,n);
x[0]=0;
for(i=1;i<=n;i++)
{
scanf("%d",&k);
if(las!=k) las=k,wz=i;
x[i]=x[wz-1]+1;
if(k==2) f[i]=f[i-1]+1;
else f[i]=f[i-1]-1;
int ll=max(0,f[i]+n-m), rr=min(f[i]+n+m,2*n);
k=ask(1,0,n+n,ll, rr)+1;
x[i]=min(k,x[i]);
modify(1,0,n+n,x[i],f[i]+n);
}
printf("%d",x[n]);
}
P2418 yyy loves OI IV的更多相关文章
- 【题解】洛谷P2418 yyy loves OI IV
感觉很是妙啊……这题数次误入歧途...最开始想的二维dp,单调队列优化:无果,卒.于是没忍住看了下标签:暴力枚举?搜索?于是开始想记忆化搜索.以为会有什么很强的剪枝之类的:30分,卒.最后终于回到正道 ...
- luoguP2418 yyy loves OI IV
https://www.luogu.org/problemnew/show/P2418 暴力 DP 做这题只有 30 分 考虑用线段树优化这个 DP 先处理一下整个房间都膜拜一个人的情况,然后将 1 ...
- [洛谷1580]yyy loves Easter_Egg I
题目背景 Soha的出题效率着实让人大吃一惊.OI,数学,化学的题目都出好了,物理的题还没有一道.于是,Huntfire,absi2011,lanlan对soha进行轮番炸,准备炸到soha出来,不料 ...
- yyy loves Easter_Egg I(恶心的字符串模拟)
题目背景 Soha的出题效率着实让人大吃一惊.OI,数学,化学的题目都出好了,物理的题还没有一道.于是,Huntfire,absi2011,redbag对soha进行轮番炸,准备炸到soha出来,不料 ...
- BZOJ 3512: DZY Loves Math IV [杜教筛]
3512: DZY Loves Math IV 题意:求\(\sum_{i=1}^n \sum_{j=1}^m \varphi(ij)\),\(n \le 10^5, m \le 10^9\) n较小 ...
- 洛谷P2397 yyy loves Maths VI (mode)
P2397 yyy loves Maths VI (mode) 题目背景 自动上次redbag用加法好好的刁难过了yyy同学以后,yyy十分愤怒.他还击给了redbag一题,但是这题他惊讶的发现自己居 ...
- 【BZOJ3512】DZY Loves Math IV(杜教筛)
[BZOJ3512]DZY Loves Math IV(杜教筛) 题面 BZOJ 求 \[\sum_{i=1}^n\sum_{j=1}^m\varphi(ij)\] 其中\(n\le 10^5,m\l ...
- P2393 yyy loves Maths II
P2393 yyy loves Maths IIlong double比如保留5位小数*1000000都变成整数最后再/1000000避免精度误差scanf("%Lf",& ...
- 洛谷P2396 yyy loves Maths VII
P2396 yyy loves Maths VII 题目背景 yyy对某些数字有着情有独钟的喜爱,他叫他们为幸运数字;然而他作死太多,所以把自己讨厌的数字成为"厄运数字" 题目描述 ...
随机推荐
- oracle网页客户端工具
Oracle数据库的管理相较于其他数据库,是比较麻烦的,客户端工具的安装都要花一些时间,目前有一款treesoft软件,通过网页的方式管理Oracle. 功能包括:数据库的展示,库表的展示,表字段结构 ...
- Java新建线程的两种方式
Java新建线程有两种方式,一种是通过继承Thread类,一种是实现Runnable接口,下面是新建线程的两种方式. 我们假设有个竞赛,有一个选手A做俯卧撑,一个选手B做仰卧起坐.分别为两个线程: p ...
- vue+element ui 的tab 动态增减,切换时提示用户是否切换
前言:工作中用到 vue+element ui 的前端框架,动态添加 Tab,删除 Tab,切换 Tab 时提示用户是否切换等,发现 element ui 有一个 bug,这里记录一下如何实现.转载 ...
- java单例模式的心得
由于设计模式对于java高级开发人员来说是非常重要的,网上也有很多关于设计模式的文章,博客等.所以,首先我对相对简单的单例模式做一个简单的总结. 一.实现方式 单例模式的实现方式有3种,分别是饿汉式, ...
- lua模块化
main.lua local main = require("my") main.greeting() my.lua local foo = {} local function g ...
- 简洁php的MVC框架
一.文件结构 建立3个文件夹 controller文件夹存放控制器文件 view文件夹存放视图文件 model文件夹存放数据文件 建立1个index.php 作为唯一入口 二.控制器 我们在contr ...
- css过渡笔记
3D http://fangyexu.com/tool-CSS3Inspector.html <!DOCTYPE html> <html lang="en" ...
- java获取本月第一天和最后一天
public class CalendarTest { public static void main(String[] args) { // 获取当前年份.月份.日期 Calendar cale = ...
- Java集合 -- HashSet 和 HashMap
HashSet 集合 HashMap 集合 HashSet集合 1.1 Set 接口的特点 Set体系的集合: A:存入集合的顺序和取出集合的顺序不一致 B:没有索引 C:存入集合的元素没有重复 1. ...
- 前端模块化方案全解(CommonJS/AMD/CMD/ES6)
模块化的开发方式可以提高代码复用率,方便进行代码的管理.通常一个文件就是一个模块,有自己的作用域,只向外暴露特定的变量和函数.目前流行的js模块化规范有CommonJS.AMD.CMD以及ES6的模块 ...