news 2026/4/27 15:41:45

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/4/24 14:45:07

TuGraph图数据库完整指南:从入门到精通的高效实践

TuGraph图数据库完整指南&#xff1a;从入门到精通的高效实践 【免费下载链接】tugraph-db TuGraph is a high performance graph database. 项目地址: https://gitcode.com/gh_mirrors/tu/tugraph-db 在当今数据驱动时代&#xff0c;图数据库正成为处理复杂关系数据的核…

作者头像 李华
网站建设 2026/4/23 14:56:19

LOOT模组排序工具:天际特别版模组管理的终极解决方案

LOOT模组排序工具&#xff1a;天际特别版模组管理的终极解决方案 【免费下载链接】skyrimse The TES V: Skyrim Special Edition masterlist. 项目地址: https://gitcode.com/gh_mirrors/sk/skyrimse LOOT模组排序工具是《上古卷轴V&#xff1a;天际 特别版》模组玩家不…

作者头像 李华
网站建设 2026/4/22 2:32:41

计算机毕业设计springboot图书管理系统 基于 SpringBoot 的馆藏自动化管理平台 SpringBoot 驱动的智慧图书馆运营系统

计算机毕业设计springboot图书管理系统mi414227&#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。在高校藏书规模逐年扩大、读者借阅需求日益多元的背景下&#xff0c;传统手工登记…

作者头像 李华
网站建设 2026/4/26 10:45:39

EspTinyUSB终极指南:ESP32S2 USB开发实战与避坑技巧

EspTinyUSB终极指南&#xff1a;ESP32S2 USB开发实战与避坑技巧 【免费下载链接】EspTinyUSB ESP32S2 native USB library. Implemented few common classes, like MIDI, CDC, HID or DFU (update). 项目地址: https://gitcode.com/gh_mirrors/es/EspTinyUSB 想要快速上…

作者头像 李华
网站建设 2026/4/21 12:30:02

嵌入式音频调试实战指南:从问题定位到系统优化

嵌入式音频调试实战指南&#xff1a;从问题定位到系统优化 【免费下载链接】xiaozhi-esp32 Build your own AI friend 项目地址: https://gitcode.com/GitHub_Trending/xia/xiaozhi-esp32 在嵌入式AI语音设备开发过程中&#xff0c;音频问题诊断往往是开发者最头疼的挑战…

作者头像 李华
网站建设 2026/4/23 0:43:37

sg3_utils终极指南:5个实用技巧轻松管理存储设备

sg3_utils终极指南&#xff1a;5个实用技巧轻松管理存储设备 【免费下载链接】sg3_utils Deprecated git-svn mirror for sg3_utils 项目地址: https://gitcode.com/gh_mirrors/sg/sg3_utils sg3_utils是一个强大的SCSI工具集&#xff0c;专门用于发送单个SCSI命令到使用…

作者头像 李华