news 2026/1/26 6:39:10

信息学奥赛一本通 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/1/25 6:24:46

企业级语音质检方案:FSMN VAD在电话录音分析中的应用

企业级语音质检方案&#xff1a;FSMN VAD在电话录音分析中的应用 1. 为什么电话录音分析需要专业VAD&#xff1f; 你有没有遇到过这样的情况&#xff1a;客服中心每天产生上万通电话录音&#xff0c;但人工抽检率不到5%&#xff0c;漏检大量服务问题&#xff1b;质检团队花80…

作者头像 李华
网站建设 2026/1/25 6:22:24

小白也能用!Qwen-Image-Layered图层拆分实战教程

小白也能用&#xff01;Qwen-Image-Layered图层拆分实战教程 你是否遇到过这样的困扰&#xff1a;一张精心设计的海报&#xff0c;想单独调整文字颜色却怕误伤背景&#xff1f;一个产品图里人物和背景粘连紧密&#xff0c;抠图后边缘毛糙、反复重试&#xff1f;或者想把旧照片…

作者头像 李华
网站建设 2026/1/25 6:22:15

2024年AI语音应用趋势:Emotion2Vec+ Large开源模型部署入门必看

2024年AI语音应用趋势&#xff1a;Emotion2Vec Large开源模型部署入门必看 1. 为什么Emotion2Vec Large值得你今天就上手 你有没有想过&#xff0c;一段3秒的语音里藏着多少情绪密码&#xff1f;不是靠猜&#xff0c;而是用AI真正“听懂”——愤怒的紧绷、惊喜的上扬、疲惫的…

作者头像 李华
网站建设 2026/1/25 6:21:55

基于Java+SpringBoot+SSM河南特色美食分享系统(源码+LW+调试文档+讲解等)/河南美食推荐系统/河南特色小吃平台/河南美食分享平台/河南地方美食系统/河南特色美食介绍系统

博主介绍 &#x1f497;博主介绍&#xff1a;✌全栈领域优质创作者&#xff0c;专注于Java、小程序、Python技术领域和计算机毕业项目实战✌&#x1f497; &#x1f447;&#x1f3fb; 精彩专栏 推荐订阅&#x1f447;&#x1f3fb; 2025-2026年最新1000个热门Java毕业设计选题…

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

Paraformer-large节能模式:空闲时自动降低GPU功耗

Paraformer-large节能模式&#xff1a;空闲时自动降低GPU功耗 语音识别模型在实际部署中&#xff0c;常常面临一个被忽视却影响深远的问题&#xff1a;GPU资源持续占用带来的隐性成本。尤其当Paraformer-large这类高性能ASR模型以离线方式长期运行Web服务时&#xff0c;即使界…

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

CAM++语音搜索功能实现:声纹检索系统搭建

CAM语音搜索功能实现&#xff1a;声纹检索系统搭建 1. 什么是CAM声纹检索系统 CAM不是简单的语音转文字工具&#xff0c;而是一个专注“听声辨人”的专业级声纹识别系统。它由开发者科哥基于达摩院开源模型二次开发而成&#xff0c;核心能力是把人的声音变成一组独特的数字指…

作者头像 李华