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

P5048 [Ynoi2019 模拟赛] Yuno loves sqrt technology III

目录

    • 题目-P5048 [Ynoi2019 模拟赛] Yuno loves sqrt technology III
    • 问题分析
    • 算法步骤
    • 代码实现

题目-P5048 [Ynoi2019 模拟赛] Yuno loves sqrt technology III

问题分析

查询区间众数出现的次数, 尝试对区间进行分块

假设已经知道了区间内众数出现的次数s ss, 那么只需要判断散列块中是否有哪个数字还能成为众数

对于每个数字记录出现的位置v vv,v [ a [ i ] ] v[a[i]]v[a[i]]代表a [ i ] a[i]a[i]出现的一些位置,p o s [ i ] pos[i]pos[i]代表a [ i ] a[i]a[i]v [ a [ i ] ] v[a[i]]v[a[i]]中的索引

假设区间内众数出现的次数是a n s ansans

  • 枚举所有左侧散列块, 假设数值是w ww, 那么只需要检查是否存在v [ w ] [ p o s [ i ] + a n s ] ≤ r v[w][pos[i] + ans] \le rv[w][pos[i]+ans]r, 就可以更新a n s ansans, 也就是算上当前位置,w ww出现的次数是a n s + 1 ans + 1ans+1
  • 枚举右侧散列块, 假设数值是w ww, 检查v [ w ] [ p o s [ i ] − a n s ] ≥ l v[w][pos[i] - ans] \ge lv[w][pos[i]ans]l, 算上当前位置,w ww出现的次数是a n s + 1 ans + 1ans+1

算法步骤

  • 初始化分块, 对数据进行离散化
  • 暴力初始化f ff数组

代码实现

#include<bits/stdc++.h>usingnamespacestd;constintN=5e5+10,M=710;intn,m,a[N];vector<int>vec;intbsize,bcnt,st[M],ed[M],b[N];vector<int>v[N];intpos[N],f[M][M],tot[N];voidinit(){bsize=sqrt(n);bcnt=(n-1)/bsize+1;for(inti=1;i<=bcnt;++i){st[i]=(i-1)*bsize+1;ed[i]=min(n,i*bsize);}for(inti=1;i<=n;++i)b[i]=(i-1)/bsize+1;sort(vec.begin(),vec.end());vec.erase(unique(vec.begin(),vec.end()),vec.end());}intfind(intx){returnlower_bound(vec.begin(),vec.end(),x)-vec.begin();}intquery(intl,intr){intx=b[l],y=b[r];if(x==y){intans=0;for(inti=l;i<=r;++i)tot[a[i]]=0;for(inti=l;i<=r;++i)ans=max(ans,++tot[a[i]]);returnans;}intans=f[x+1][y-1];for(inti=l;i<=ed[x];++i){intt=pos[i];if(i+t<v[a[i]].size()&&v[a[i]][i+t]<=r)ans++;}for(inti=st[y];i<=r;++i){intt=pos[i];if(t-ans>=0&&v[a[i]][t-ans]>=l)ans++;}returnans;}intmain(){ios::sync_with_stdio(false);cin.tie(0);cin>>n>>m;for(inti=1;i<=n;++i)cin>>a[i],vec.push_back(a[i]);init();for(inti=1;i<=n;++i)a[i]=find(a[i]);for(inti=1;i<=n;++i){v[a[i]].push_back(i);pos[i]=v[a[i]].size();pos[i]--;}for(inti=1;i<=bcnt;++i){memset(tot,0,sizeoftot);for(intj=i;j<=bcnt;++j){f[i][j]=f[i][j-1];for(intk=st[j];k<=ed[j];++k){f[i][j]=max(f[i][j],++tot[a[k]]);}}}intlast=0;while(m--){intl,r;cin>>l>>r;l^=last,r^=last;if(r<l)swap(l,r);intans=query(l,r);cout<<ans<<'\n';last=ans;}return0;}
http://www.rkmt.cn/news/122318.html

相关文章:

  • 精通Java LaTeX渲染:JLaTeXMath实战应用全解析
  • 2026年仪器信息平台/仪器网站发展前景及网站推荐 - 品牌推荐大师1
  • 2026年仪器信息平台/仪器网站发展前景及网站推荐 - 品牌推荐大师1
  • Omnissa Horizon 8 2512 发布 - 虚拟桌面基础架构 (VDI) 和应用软件
  • 期末复习:结构算法题
  • 极速组态!Profinet转Ethernet网关让ABB机器人主站秒连工业网络(上集)
  • 2025年12月写字楼电梯维保,小区电梯维保,酒店电梯维保公司推荐:行业测评与选择指南 - 品牌鉴赏师
  • 2025 年 12 月仓储货架厂家实力推荐榜:重型/模具/悬臂/立体/阁楼/高位货架,超强承重与空间优化解决方案精选 - 品牌企业推荐师(官方)
  • 2025年发电机租赁厂家最新推荐:重庆康合机电实力解析报告出炉! - 深度智识库
  • 3步解锁YesPlayMusic:高颜值音乐播放器的实用指南
  • linux和win的换行符转换
  • 终极指南:Bark推送通知的个性化定制全攻略
  • Stable Diffusion 2.1 Base:从零开始的AI绘画终极指南
  • 原圈科技推动金融业AI营销内容生产合规升级的关键实践
  • Obsidian终极模板插件Templater快速上手指南:打造智能化笔记系统
  • Android USB相机开发实战:从零构建OTG摄像头集成方案
  • 5大实用功能!南方电网电费数据智能管理全攻略
  • PyTorch InfoNCE损失函数实战指南:从原理到工程应用
  • 2025 年国内口碑好的镍卷厂行业热销排行榜 - 朴素的承诺
  • 5个必知技巧:用Mushroom卡片打造你的专属智能家居控制中心
  • AndroidStudio的时候顶部的模拟器一直是loading状态无法连接设备
  • 2025雅思培训价值榜:质量突围,多次元教育以98.6分引领行业价值重构 - 速递信息
  • 2025年东莞凤岗搬家公司权威推荐榜单:东莞专业搬家/东莞中堂搬家/东莞清溪搬家源头服务商精选 - 品牌推荐官
  • 2025年旗鱼王游泳耳机工厂威推荐榜单:防水耳机/鸿鑫达耳机/游泳专业耳机源头工厂精选 - 品牌推荐官
  • 推荐几家专业的隧道炉工厂及行业应用参考 - 品牌排行榜
  • 国内隧道炉厂家有哪些?行业实力企业及产品特点解析 - 品牌排行榜
  • 2025纸杯成型机设备采购宝典:全伺服纸杯机、超声波纸杯机、纸盘机等厂家最新路线捋清 - 品牌2026
  • 57、家庭局域网搭建与使用全攻略
  • (二)数字信号处理中卷积与相关的联系 - 实践
  • MathLive 终极指南:2025年最简单上手的网页数学公式编辑器