news 2026/6/13 20:36:30

信息学奥赛一本通 1463:门票

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
信息学奥赛一本通 1463:门票

【题目链接】

ybt 1463:门票

【题目考点】

1. 哈希表

相关知识见:【模板:哈希表】信息学奥赛一本通 1456:【例题2】图书管理

【解题思路】

解法1:链地址法实现哈希表

数据范围限制为65536 K B 65536KB65536KB
哈希表中最多可能保存2 ∗ 10 6 2*10^62106个元素,平均每个元素占用内存65536 ∗ 1024 / ( 2 ∗ 10 6 ) ≈ 33 B 65536*1024/(2*10^6)\approx 33B655361024/(2106)33B
使用STL中的unordered_set类,内存开销比较大,当存储元素个数达到2 ∗ 10 6 2*10^62106时,容易发生内存超限。
因此本题必须手动实现哈希表。
开放地址法对内存空间需求较大,需要保证负载因子较小(一般为0.7)才可以降低哈希冲突的概率,因此表长会比存储的元素数量更大,有很多空间不能保存数据,对空间需求较高。
而链地址法的负载因子可以大于1,对内存空间需求相对较小,较为灵活。
参考【模板:哈希表】信息学奥赛一本通 1456:【例题2】图书管理中解法2可以以链地址法实现哈希表。
可以选择将哈希表写成类,或只是声明全局数组和函数来实现。

本题给定了初值a 0 = 1 a_0=1a0=1,以及递推公式( A ⋅ a i + a i m o d B ) m o d C (A\cdot a_i+a_i\bmod B)\bmod C(Aai+aimodB)modC,想要求出第一次出现重复项的编号。即当求出的值为a i a_iai时,如果a i a_iai在先前已经出现过,就输出i ii
如果答案超过2 ∗ 10 6 2*10^62106,就输出-1。
我们可以根据a aa序列的初始值和递推式,依次递推求出a aa序列的每一项,设其中的一项为d dd。注意A ⋅ a i A\cdot a_iAai这一步要在long long类型下进行计算。
当求出a i = d a_i=dai=d时,首先在哈希表中查找是否存在d dd

  • 如果哈希表中存在d dd,则输出i ii,结束程序。
  • 如果哈希表中不存在d dd,则将d dd插入哈希表。

循环次数为2 ∗ 10 6 2*10^62106,如果跳出了循环,则输出-1。

【题解代码】

解法1:链地址法实现哈希表

  • 写法1:写全局数组和函数实现哈希表,链表中结点地址为int类型
#include<iostream>#include<algorithm>usingnamespacestd;#defineN2000003structNode{intval;intnext;}node[N];intp,data[N];//data[i]:哈希值为i的单链表的第一个结点的地址intHash(intkey){returnkey%N;}voidinsert(intkey){inth=Hash(key),np=++p;node[np].val=key;node[np].next=data[h];data[h]=np;}intcount(intkey){inth=Hash(key);for(inti=data[h];i!=0;i=node[i].next)if(node[i].val==key)return1;return0;}intmain(){inta,b,c,d=1;cin>>a>>b>>c;insert(d);for(inti=1;i<=2000000;++i){d=((longlong)a*d+d%b)%c;if(count(d)==1){cout<<i;return0;}elseinsert(d);}cout<<-1;return0;}
  • 写法2:实现HashSet类,链表中结点地址为Node*类型
#include<bits/stdc++.h>usingnamespacestd;#defineN2000003structHash{unsignedoperator()(intkey){returnkey%N;}};template<classT,classHashFunc>structHashSet//开散列{structNode{T key;Node*next=nullptr;}node[N],*p=node,*data[N]={};HashFunc hash;voidinsert(T key){//头插法if(count(key)==1)//如果哈希表中已经存在key,则不插入return;inth=hash(key);Node*np=++p;np->key=key;;np->next=data[h];data[h]=np;}intcount(T key)//获取关键字key的个数{inth=hash(key);for(Node*i=data[h];i!=nullptr;i=i->next)if(i->key==key)return1;return0;}};HashSet<int,Hash>hs;intmain(){inta,b,c,d=1;cin>>a>>b>>c;hs.insert(d);for(inti=1;i<=2000000;++i){d=((longlong)a*d+d%b)%c;if(hs.count(d)==1){cout<<i;return0;}elsehs.insert(d);}cout<<-1;return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/7 12:28:50

麦橘超然制造业应用:产品设计草图AI生成落地案例

麦橘超然制造业应用&#xff1a;产品设计草图AI生成落地案例 1. 为什么制造业需要“会画图”的AI&#xff1f; 你有没有见过这样的场景&#xff1a;工业设计师在电脑前反复修改一张机械结构草图&#xff0c;改了七版&#xff0c;客户还是说“感觉不够有科技感”&#xff1b;或…

作者头像 李华
网站建设 2026/6/13 1:20:28

verl多GPU并行部署教程:模块化API实操手册

verl多GPU并行部署教程&#xff1a;模块化API实操手册 1. verl 是什么&#xff1f;为什么需要它&#xff1f; 你可能已经听说过大模型后训练&#xff08;post-training&#xff09;这个概念——它不是从零开始训练一个模型&#xff0c;而是在已有预训练语言模型基础上&#x…

作者头像 李华
网站建设 2026/6/13 12:02:59

Qwen-Image-Layered新手指南:从安装到运行全流程解析

Qwen-Image-Layered新手指南&#xff1a;从安装到运行全流程解析 摘要&#xff1a;Qwen-Image-Layered 是一个专注于图像图层化分解的轻量级工具&#xff0c;它能将单张输入图像智能拆解为多个独立可控的 RGBA 图层。这种结构天然支持高保真编辑——你可单独调整某一层的位置、…

作者头像 李华
网站建设 2026/6/13 20:01:06

Multisim示波器保存波形数据方法:实用操作指南

以下是对您提供的博文内容进行 深度润色与结构优化后的专业级技术文章 。整体风格更贴近一位资深电子工程师/高校实验课教师在技术社区中自然、扎实、有温度的分享,彻底去除AI腔调和模板化痕迹,强化实操逻辑、教学语感与工程洞察力,同时严格遵循您提出的全部格式与表达要求…

作者头像 李华
网站建设 2026/6/13 18:39:59

Java基于SpringBoot的健身俱乐部网站,附源码+文档说明

博主介绍&#xff1a;✌Java老徐、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;&…

作者头像 李华
网站建设 2026/6/13 7:34:07

从PPO到GRPO:Unsloth如何简化强化学习流程

从PPO到GRPO&#xff1a;Unsloth如何简化强化学习流程 在大模型微调实践中&#xff0c;强化学习&#xff08;RL&#xff09;一直以“高门槛、高显存、难调试”著称。传统PPO训练动辄需要4张A100起步&#xff0c;单卡用户只能望而却步。而今天要介绍的Unsloth框架&#xff0c;正…

作者头像 李华