IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 可持久化线段树11(简单剪枝) -> 正文阅读

[数据结构与算法]可持久化线段树11(简单剪枝)

CF840D Destiny

比价简单的主席树的题目,感觉分块也可以做。,没试过

根据题目意思,要求区间[l,r]中出现次数大于(r-l+1)/k的数中最小的数

一看和出现次数有关,基本就是主席树无疑了。

建树也比较简单,先离散化,后按一般主席树插入的方式建树即可。

查询也很简单,先看左子树,是否存在答案,如果存在答案,则不进入右子树,否则进入(这就是剪枝)

详见代码

#pragma GCC optimize(2)
#pragma GCC optimize(3,"Ofast","inline")
#include <bits/stdc++.h>
#define inf 0x7fffffff
//#define ll long long
//#define int long long
//#define double long double
#define re register int
#define void inline void
#define eps 1e-8
//#define mod 1e9+7
#define ls(p) p<<1
#define rs(p) p<<1|1
#define pi acos(-1.0)
#define pb push_back
#define P pair < int , int > 
#define mk make_pair
using namespace std;
const int mod=1e9+7;
const int M=1e8+5;
const int N=6e5+5;//?????????? 4e8
int a[N],b[N],rt[N];
int tot,n,q,m;
struct node
{
	int l,r,sum;
}e[N*40];
void insert(int &p,int pre,int l,int r,int d)
{
	e[++tot]=e[pre];
	p=tot;
	e[tot].sum++;
	if(l==r)  return;
	int mid=(l+r)>>1;
	if(d<=mid)  insert(e[p].l,e[pre].l,l,mid,d);
	else  insert(e[p].r,e[pre].r,mid+1,r,d);
}
int ask(int L,int R,int l,int r,int k)
{
	if(l==r)
	{
		if(e[R].sum-e[L].sum>k)  return l;
		else  return 1e9;
	}
	int mid=(l+r)>>1;
	int tl=e[e[R].l].sum-e[e[L].l].sum;
	int tr=e[e[R].r].sum-e[e[L].r].sum;
	int ans=1e9;
	if(tl>k)  ans=min(ans,ask(e[L].l,e[R].l,l,mid,k));
	if(tr>k&&ans==1e9)  ans=min(ans,ask(e[L].r,e[R].r,mid+1,r,k));
	return ans;
}
void solve()
{
	cin>>n>>q;
	for(re i=1;i<=n;i++)  scanf("%d",&a[i]),b[i]=a[i];
	sort(b+1,b+n+1);m=unique(b+1,b+n+1)-(b+1);
	for(re i=1;i<=n;i++)  insert(rt[i],rt[i-1],1,m,lower_bound(b+1,b+m+1,a[i])-b);
	while(q--)
	{
		int l,r,k;
		scanf("%d%d%d",&l,&r,&k);
		int ans=ask(rt[l-1],rt[r],1,m,(r-l+1)/k);
		if(ans==1e9)  ans=-1;
		else  ans=b[ans];
		printf("%d\n",ans);
	} 
}
signed main()
{
    int T=1;
//    cin>>T;
    for(int index=1;index<=T;index++)
    {
//    	printf("Case %d:\n",index);
        solve();
//        puts("");
    }
    return 0;
}
/*


5
10101
11
accd
acd
aaaaababa
ababa
aaaababa
ababa
avababa
ababa



 
*/ 
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-07-25 00:01:44  更:2021-07-25 00:01:53 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/28 12:11:42-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码