news 2026/5/26 5:49:56

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/24 17:19:08

精通Java LaTeX渲染:JLaTeXMath实战应用全解析

精通Java LaTeX渲染&#xff1a;JLaTeXMath实战应用全解析 【免费下载链接】jlatexmath A Java API to render LaTeX 项目地址: https://gitcode.com/gh_mirrors/jl/jlatexmath 在Java开发中&#xff0c;如何高效渲染复杂的数学公式一直是个技术难题。JLaTeXMath作为专业…

作者头像 李华
网站建设 2026/5/25 19:22:35

C++ 对象池 (objPool) 模块设计与实现分析

个人专著《C++元编程与通用设计模式实现》由清华大学出版社出版。该书内容源于工业级项目实践,出版后市场反馈积极(已加印)。其专业价值获得了图书馆系统的广泛认可:不仅被中国国家图书馆作为流通与保存本收藏,还被近半数省级公共图书馆及清华大学、浙江大学等超过35所高校…

作者头像 李华
网站建设 2026/5/25 11:13:51

如何高效定制B站API认证凭证:全新Cookies配置指南

掌握B站API调用的核心技巧&#xff01;本文将为你详细解析bilibili-api项目最新推出的自定义Credential Cookies功能&#xff0c;帮助你快速实现灵活的身份认证配置。 【免费下载链接】bilibili-api 哔哩哔哩常用API调用。支持视频、番剧、用户、频道、音频等功能。原仓库地址&…

作者头像 李华
网站建设 2026/5/25 12:00:18

immunedeconv免疫细胞去卷积工具完整指南:从入门到精通

immunedeconv免疫细胞去卷积工具完整指南&#xff1a;从入门到精通 【免费下载链接】immunedeconv 项目地址: https://gitcode.com/gh_mirrors/imm/immunedeconv 在肿瘤免疫研究领域&#xff0c;准确解析组织样本中各类免疫细胞的比例分布是理解肿瘤微环境复杂性的关键…

作者头像 李华
网站建设 2026/5/25 12:00:32

如何快速搭建企业级开源视频会议平台:Nettu Meet完整指南

如何快速搭建企业级开源视频会议平台&#xff1a;Nettu Meet完整指南 【免费下载链接】nettu-meet Open source video conferencing system for tutors. 项目地址: https://gitcode.com/gh_mirrors/ne/nettu-meet 在远程办公成为新常态的背景下&#xff0c;企业对于安全…

作者头像 李华
网站建设 2026/5/23 23:16:13

OpenVidu实战部署:从零构建企业级视频会议系统

OpenVidu实战部署&#xff1a;从零构建企业级视频会议系统 【免费下载链接】openvidu OpenVidu Platform main repository 项目地址: https://gitcode.com/gh_mirrors/op/openvidu 在远程协作成为常态的今天&#xff0c;如何快速搭建稳定可靠的视频会议平台成为众多企业…

作者头像 李华