【集训Day2 哈希表】【NHOI2015】【Luogu P2421】差
LuoguP2421
原题来自NHOI2015
【解题思路】
本题的解题方法有三种,一种为枚举减数,二分查找被减数。第二种为利用数据单调性用尺取法进行查找,第三种为运用哈希表以快速查找数据。
【解题反思】
- 一题可能有多种解法,尝试选择自己最擅长的。
【参考程序】
#include<iostream>
#include<cstdio>
using namespace std;
int n,a[100001],i,j,ans,s,c;
int main()
{
freopen("dec.in","r",stdin);
freopen("dec.out","w",stdout);
cin>>n>>c;
for (int k=1;k<=n;k++) cin>>a[k];
i=1;
j=i+1;a[i-1]=-1;
while (i<=n)
{
if (a[j]-a[i]<c)//如果差值小了,那么增大被减数
{
j++;
}
else if (a[j]-a[i]>c||j>n)//如果差值大了,那么增大减数
{
i++;
if (a[i]==a[i-1]) ans+=s;//如果与前一个统计的相同,意味着无需再次统计
else s=0;
}
else if (a[j]-a[i]==c)//如果相等,那么统计并且增大被减数
{
j++;
ans++;
s++;
}
}
cout<<ans;
return 0;
}
以上是尺取法
#include<iostream>
#include<cstdio>
using namespace std;
int a[100001];
int n,c,ans,b,tmp;
int main()
{
freopen("dec.in","r",stdin);
freopen("dec.out","w",stdout);
cin>>n>>c;
int j=1;
for (int i=1;i<=n;i++) cin>>a[i];
for (int i=1;i<=n;i++)
{
int l=0,r=n+1,mid;
while (l<r-1)
{
mid=(l+r)/2;
if (a[mid]-a[i]>=c) r=mid;
if (a[mid]-a[i]<c) l=mid;
}//查找被减数在数据中最开始的位置
tmp=r;
l=0;r=n+1;
while (l<r-1)
{
mid=(l+r)/2;
if (a[mid]-a[i]<=c) l=mid;
if (a[mid]-a[i]>c) r=mid;
}//查找被减数在数据中最后出现的位置
ans+=l-tmp+1;//统计
}
cout<<ans;
return 0;
}
上为二分查找法
#include<iostream>
#include<cstdio>
using namespace std;
const int mod=1000007;
int hash[mod+5],count[mod+5],n,c,ans,a[100001];
void add(int s)//将该数压入哈希表
{
int cod=s%mod;
while (hash[cod]!=s&&hash[cod]!=0)//线性探测法解决哈希表冲突
{
cod++;
cod%=mod;
}
hash[cod]=s;
count[cod]++;
}
int find(int s)//在哈希表中寻找该数值
{
int cod=s%mod;
while (hash[cod]!=s&&hash[cod]!=0)//线性探测
{
cod++;
cod%=mod;
}
if (hash[cod]==s) return cod;
else return 0;
}
int main()
{
freopen("dec.in","r",stdin);
freopen("dec.out","w",stdout);
cin>>n>>c;
for (int i=1;i<=n;i++)
{
cin>>a[i];
add(a[i]);
}
for (int i=1;i<=n;i++)
{
int p=find(a[i]+c);
if (p!=0) ans+=count[p];
}
cout<<ans;
return 0;
}
上为哈希表法
【集训Day2 哈希表】【NHOI2015】【Luogu P2421】差的更多相关文章
- [PHP内核探索]PHP中的哈希表
在PHP内核中,其中一个很重要的数据结构就是HashTable.我们常用的数组,在内核中就是用HashTable来实现.那么,PHP的HashTable是怎么实现的呢?最近在看HashTable的数据 ...
- Java 哈希表运用-LeetCode 1 Two Sum
Given an array of integers, find two numbers such that they add up to a specific target number. The ...
- ELF Format 笔记(十五)—— 符号哈希表
ilocker:关注 Android 安全(新手) QQ: 2597294287 符号哈希表用于支援符号表的访问,能够提高符号搜索速度. 下表用于解释该哈希表的组织,但该格式并不属于 ELF 规范. ...
- Java基础知识笔记(一:修饰词、向量、哈希表)
一.Java语言的特点(养成经常查看Java在线帮助文档的习惯) (1)简单性:Java语言是在C和C++计算机语言的基础上进行简化和改进的一种新型计算机语言.它去掉了C和C++最难正确应用的指针和最 ...
- 什么叫哈希表(Hash Table)
散列表(也叫哈希表),是根据关键码值直接进行访问的数据结构,也就是说,它通过把关键码值映射到表中一个位置来访问记录,以加快查找的速度.这个映射函数叫做散列函数,存放记录的数组叫做散列表. - 数据结构 ...
- 【哈希表】CodeVs1230元素查找
一.写在前面 哈希表(Hash Table),又称散列表,是一种可以快速处理插入和查询操作的数据结构.哈希表体现着函数映射的思想,它将数据与其存储位置通过某种函数联系起来,其在查询时的高效性也体现在这 ...
- openssl lhash 数据结构哈希表
哈希表是一种数据结构,通过在记录的存储位置和它的关键字之间建立确定的对应关系,来快速查询表中的数据: openssl lhash.h 为我们提供了哈希表OPENSSL_LHASH 的相关接口,我们可以 ...
- Berkeley DB的数据存储结构——哈希表(Hash Table)、B树(BTree)、队列(Queue)、记录号(Recno)
Berkeley DB的数据存储结构 BDB支持四种数据存储结构及相应算法,官方称为访问方法(Access Method),分别是哈希表(Hash Table).B树(BTree).队列(Queue) ...
- python数据结构与算法——哈希表
哈希表 学习笔记 参考翻译自:<复杂性思考> 及对应的online版本:http://greenteapress.com/complexity/html/thinkcomplexity00 ...
随机推荐
- Redux的核心概念,实现代码与应用示例
Redux是一种JavaScript的状态管理容器,是一个独立的状态管理库,可配合其它框架使用,比如React.引入Redux主要为了使JavaScript中数据管理的方便,易追踪,避免在大型的Jav ...
- 数据结构(四十一)多路查找树(B树)
一.多路查找树的背景 前面所讨论的查找算法都是在内存中进行的,它们适用于较小的文件,而对于较大的.存放在外存储器上的文件就不合适了,对于此类大规模的文件,即使是采用了平衡二叉树,在查找效率上仍然较低. ...
- C语言中为什么float型数据的范围是3.4E-38~3.4E+38
因为float所占的位数决定了他的大小位数就是计算机的存储所需要的bit多少32位浮点,64位双精度浮点范围不同//////////////////////以前学计算系统基础的时候有这么个说法计算机存 ...
- JavaFX简介和Scene Builder工具的安装使用简易教程
JavaFX概述和简介 富互联网应用是那些提供与Web应用程序类似的功能,并可作为桌面应用程序体验的应用.与用户的正常网络应用程序相比,它们提供更好的视觉体验.这些应用程序可作为浏览器插件或作为虚拟机 ...
- 条款03:尽肯使用const
定义常量 define 是一个Compile-Time的概念,它的生命周期止于编译器期,它存在与程序的代码段,在实际程序中它只是一个常数.一个命令中的参数.并没有实际的存在 const常量存在于程序的 ...
- 修改tomcat默认使用的jdk版本
1.windows平台 在csetclasspath.bat文件开头加上如下两句(指定JDK): set JAVA_HOME=C:\Program Files\Java\jdk1.7.0_79 se ...
- python-->二进制的用法
1.10进制转换为其他进制 方法一:函数 十进制转二进制:bin(10) --> '0b1010' tpye:是字符串类型 0b:表示2进制 十进制转八进制:oct(10) --> '0o ...
- CSPS模拟 67
炸分炸的厉害.(当然这跟b哥定律无关 话说好久没人嘲笑我菜了,快飘的不知道到哪了. 谁能讽我两句我不要面子的. 另外在博客上写些没用的东西好浪费精力啊我又不想当网红 主要是考试的时候心态不稳. 以为T ...
- KETTLE常见问题和优化
1.创建MySQL空资源库报错问题:因为boolean类型的问题,Mysql中的boolean类型实际上保存为TINYINT,需要手动的修改生成资源库的sql脚本,将其中的插入用户ENABLED的值由 ...
- Elasticsearch 技术分析(八):剖析 Elasticsearch 的索引原理
前言 创建索引的时候,我们通过Mapping 映射定义好索引的基本结构信息,接下来我们肯定需要往 ES 里面新增业务文档数据了,例如用户,日志等业务数据.新增的业务数据,我们根据 Mapping 来生 ...