BZOJ 1109 POI2007 堆积木Klo LIS
题目大意:给定一个序列,能够多次将某个位置的数删掉并将后面全部数向左串一位,要求操作后a[i]=i的数最多
首先我们如果最后a[i]=i的数的序列为S
那么S满足随着i递增,a[i]递增(相对位置不变),i-a[i]单调不减(后面的不会比前面移动的少)
这是一个三维偏序问题
要是不看题解我就真去写CDQ分治了233
我们发现i=(i-a[i])+a[i]
也就是说假设一个序列满足i-a[i]单调不减且a[i]单调递增 那么i一定单调递增
于是就剩两维偏序了 LIS走起吧= =
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#define M 100100
using namespace std;
struct abcd{
int x,y;
bool operator < (const abcd &a) const
{
if(x!=a.x)
return x<a.x;
return y<a.y;
}
}b[M];
int n,tot,ans,a[M];
namespace BIT{
int c[M];
void Update(int x,int y)
{
for(;x<=n;x+=x&-x)
c[x]=max(c[x],y);
}
int Get_Ans(int x)
{
int re=0;
for(;x;x-=x&-x)
re=max(re,c[x]);
return re;
}
}
int main()
{
using namespace BIT;
int i;
cin>>n;
for(i=1;i<=n;i++)
{
scanf("%d",&a[i]);
if(i<a[i]) continue;
b[++tot].x=i-a[i];
b[tot].y=a[i];
}
sort(b+1,b+tot+1);
for(i=1;i<=tot;i++)
{
int temp=Get_Ans(b[i].y-1)+1;
ans=max(ans,temp);
Update(b[i].y,temp);
}
cout<<ans<<endl;
return 0;
}
BZOJ 1109 POI2007 堆积木Klo LIS的更多相关文章
- BZOJ 1109: [POI2007]堆积木Klo
		1109: [POI2007]堆积木Klo Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 948 Solved: 341[Submit][Statu ... 
- bzoj 1109 [POI2007]堆积木Klo(LIS)
		[题意] n个数的序列,删除一个数后序列左移,求最后满足i==a[i]的最大个数. [思路] 设最终得到a[i]==i的序列为s,则s应满足: i<j,a[i]<a[j],i-a[i]&l ... 
- BZOJ.1109.[POI2007]堆积木Klo(DP LIS)
		BZOJ 二维\(DP\)显然.尝试换成一维,令\(f[i]\)表示,强制把\(i\)放到\(a_i\)位置去,现在能匹配的最多数目. 那么\(f[i]=\max\{f[j]\}+1\),其中\(j& ... 
- BZOJ 1109 [POI2007]堆积木Klo(树状数组)
		[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1109 [题目大意] Mary在她的生日礼物中有一些积木.那些积木都是相同大小的立方体. ... 
- 1109: [POI2007]堆积木Klo
		1109: [POI2007]堆积木Klo https://lydsy.com/JudgeOnline/problem.php?id=1109 分析: 首先是dp,f[i]表示到第i个的最优值,f[i ... 
- 【BZOJ】1109: [POI2007]堆积木Klo
		题意 \(n(1 \le n \le 100000)\)个数放在一排,可以一走一些数(后面的数向前移),要求最大化\(a_i=i\)的数目. 分析 分析容易得到一个dp方程. 题解 \(d(i)\)表 ... 
- 【BZOJ1109】[POI2007]堆积木Klo 二维偏序
		[BZOJ1109][POI2007]堆积木Klo Description Mary在她的生日礼物中有一些积木.那些积木都是相同大小的立方体.每个积木上面都有一个数.Mary用他的所有积木垒了一个高塔 ... 
- BZOJ1109 : [POI2007]堆积木Klo
		f[i]表示第i个在自己位置上的最大值 则f[i]=max(f[j])+1 其中 j<i a[j]<a[i] a[i]-a[j]<=i-j -> j-a[j]<=i-a[ ... 
- 【bzoj1109】[POI2007]堆积木Klo  动态规划+树状数组
		题目描述 Mary在她的生日礼物中有一些积木.那些积木都是相同大小的立方体.每个积木上面都有一个数.Mary用他的所有积木垒了一个高塔.妈妈告诉Mary游戏的目的是建一个塔,使得最多的积木在正确的位置 ... 
随机推荐
- 请问,如何在windows系统下面同时使用中文和英文的cmd?_百度知道
			请问,如何在windows系统下面同时使用中文和英文的cmd?_百度知道 在批处理开始加一行chcp 437就是英文的cmdchcp 936就是中文的cmd 
- autotools入门笔记(一)
			GNU autotools作用:收集系统配置信息并自动生成Makefile文件. GNU autotools主要包括三个工具:autoconf.automake.libtool,还有很多辅助的工具,包 ... 
- VC/MFC 当鼠标移到控件上时显示提示信息
			VC/MFC 当鼠标移到控件上时显示提示信息 ToolTip是Win32中一个通用控件,MFC中为其生成了一个类CToolTipCtrl,总的说来其使用方法是较简单的,下面讲一下它的一般用法和高级用法 ... 
- vs2008中使用gdi+的设置
			vs2008中使用gdi+ 1.新建一个mfc工程 2.在stdafx.h文件中加入以下几行语句: #include <gdiplus.h> //#pragm ... 
- DirectX SDK版本与Visual Studio版本
			对于刚刚接触 DirectShow 的人来说,安装配置是一个令人头疼的问题,经常出现的情况是最基本的 baseclass 就无法编译.一开始我也为此费了很大的功夫,比如说修改代码.修改编译选项使其编译 ... 
- 让Android中的webview支持页面中的文件上传
			android webview在默认情况下是不支持网页中的文件上传功能的: 如果在网页中有<input type="file" />,在android webview中 ... 
- Swift - 标签条(UITabBar)标签页控制器(UITabBarController)用法
			App底部的tab标签页可以方便的把功能模块划分清楚,只需点击相应的标签页就可以展示完全独立的视图页面,同时各标签页间的视图也可以进行数据交换. TabBarItem系统自带图标样式(System ... 
- svn跨机备份
			#!/bin/sh svn_bak_dir='/svndata/cloudil' svn_server='svn://172.16.40.200:9999' user=adminread pass=a ... 
- WM_PAINT产生原因有2种(用户操作和API)——WM_PAINT和WM_ERASEBKGND产生时的先后顺序不一定(四段讨论)
			1. 当WM_PAINT不是由InvalidateRect产生时,即由最大化,最小化等产生时,或者移动产生(移动有时只会产生WM_ERASEBKGND消息)系统先发送WM_ERASEBKGND消息,再 ... 
- VC 中与字符串相关的宏 _T、TEXT,_TEXT、L 的作用(简单明了)
			一. 在字符串前加一个L作用: 如 L"我的字符串" 表示将ANSI字符串转换成unicode的字符串,就是每个字符占用两个字节. strlen("as ... 
