当前位置: 首页 > news >正文

BZOJ 1878 SDOI2009 HH的项链 树状数组/莫队算法

题目大意:给定一个序列。求一个区间内有多少个不同的数

正解是树状数组 将全部区间依照左端点排序 然后每次仅仅统计左端点開始的每种颜色的第一个数即可了 用树状数组维护

我写的是莫队算法 莫队明显能搞 m√m明显慢了点可是还是能接受的一个复杂度

一開始离散化数组开小了各种秒RE…… 跪了

#include<cmath>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define M 50500
using namespace std;
struct abcd{
	int l,r,pos;
	bool operator < (const abcd &x) const;
}q[200200];
int n,m,block,l=1,r=0,now,a[M],map[1001001],tot;
int cnt[M],ans[200200];
bool abcd :: operator < (const abcd &x) const
{
	if( (l-1)/block == (x.l-1)/block )
		return r < x.r ;
	return (l-1)/block < (x.l-1)/block ;
}
inline void Update(int x)
{
	cnt[x]++;
	if(cnt[x]==1)
		++now;
}
inline void Downdate(int x)
{
	cnt[x]--;
	if( !cnt[x] )
		--now;
}
int main()
{
	int i,x;
	cin>>n;
	for(i=1;i<=n;i++)
	{
		scanf("%d",&x);
		if(!map[x]) map[x]=++tot;
		a[i]=map[x];
	}
	cin>>m;
	for(i=1;i<=m;i++)
		scanf("%d%d",&q[i].l,&q[i].r),q[i].pos=i;
	block=static_cast<int>(sqrt(n)+1e-7);
	sort(q+1,q+m+1);
	for(i=1;i<=m;i++)
	{
		while(r<q[i].r)
			Update(a[++r]);
		while(l>q[i].l)
			Update(a[--l]);
		while(r>q[i].r)
			Downdate(a[r--]);
		while(l<q[i].l)
			Downdate(a[l++]);
		ans[q[i].pos]=now;
	}
	for(i=1;i<=m;i++)
		printf("%d\n",ans[i]);
}


相关文章:

  • 数据库对象
  • 中文分词--逆向最大匹配
  • servlet文件下载2(单文件下载和批量下载)
  • php 上传文件
  • 程序员工作中绕不开的9大问题,你遇到过几个?
  • Adobe将于2020年末停止对Flash的支持
  • quick-cocos2d-x教程9:实例之加上背景图片
  • iOS将数组中的内容分拼接成字符串
  • 如何使用阿里云虚拟主机搭建博客(二)搭建篇
  • create-react-app做的留言板
  • 中国式社交网络就一个“约”字而已
  • 测试人员的GitHub
  • 《企业级ios应用开发实战》一3.7 本章小结
  • GeekPwn黑客选手任意操纵智能烤箱 智能家居存隐患
  • 迈克菲报告指出网络威胁情报共享的阻碍
  • CSS选择器——伪元素选择器之处理父元素高度及外边距溢出
  • CSS中外联样式表代表的含义
  • github指令
  • Javascript 原型链
  • java中的hashCode
  • JDK9: 集成 Jshell 和 Maven 项目.
  • JS数组方法汇总
  • Linux快速配置 VIM 实现语法高亮 补全 缩进等功能
  • Node.js 新计划:使用 V8 snapshot 将启动速度提升 8 倍
  • SegmentFault 社区上线小程序开发频道,助力小程序开发者生态
  • Spring Boot MyBatis配置多种数据库
  • Web设计流程优化:网页效果图设计新思路
  • 计算机在识别图像时“看到”了什么?
  • 前端每日实战 2018 年 7 月份项目汇总(共 29 个项目)
  • 什么软件可以剪辑音乐?
  • 这几个编码小技巧将令你 PHP 代码更加简洁
  • ​io --- 处理流的核心工具​
  • $.each()与$(selector).each()
  • (10)Linux冯诺依曼结构操作系统的再次理解
  • (附源码)springboot社区居家养老互助服务管理平台 毕业设计 062027
  • (过滤器)Filter和(监听器)listener
  • (九十四)函数和二维数组
  • (提供数据集下载)基于大语言模型LangChain与ChatGLM3-6B本地知识库调优:数据集优化、参数调整、Prompt提示词优化实战
  • (转)甲方乙方——赵民谈找工作
  • .net 设置默认首页
  • .NET 依赖注入和配置系统
  • .net6使用Sejil可视化日志
  • .net程序集学习心得
  • .NET导入Excel数据
  • @ModelAttribute 注解
  • [Android View] 可绘制形状 (Shape Xml)
  • [Android] Implementation vs API dependency
  • [BZOJ3211]:花神游历各国(小清新线段树)
  • [bzoj4010][HNOI2015]菜肴制作_贪心_拓扑排序
  • [datastore@cyberfear.com].Elbie、[thekeyishere@cock.li].Elbie勒索病毒数据怎么处理|数据解密恢复
  • [Django 0-1] Core.Checks 模块
  • [HXPCTF 2021]includer‘s revenge
  • [J2ME]如何替换Google Map静态地图自带的Marker
  • [LeetCode] NO. 387 First Unique Character in a String
  • [LeetCode] Verify Preorder Sequence in Binary Search Tree 验证二叉搜索树的先序序列