[JLOI2011]不重复数字
原题链接
题解
题目大意:
给出N个数,要求把其中重复的去掉,只保留第一次出现的数。
最后按顺序输出
N <= 50000
然这题是个哈希的典型题目
HASH,我对于它的理解就是一个桶%一个数,当然并不是如此,有很多更好的HASH函数可以更好的减少冲突,例如非十进制数等。
HASH一般用来处理一个元素是否在一个集合内,大部分的时候二分查找+快速排序可以代替这个功能(STL中也有专门用来去重的),但在有些题目的运用上,则必须用到HASH
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cctype>
using namespace std;
typedef long long ll;
const int N=5e4+;
ll f[N];
int T,n,z;
inline ll read()//读入优化
{
ll X=,w=; char ch=;
while(!isdigit(ch)) {w|=ch=='-';ch=getchar();}
while(isdigit(ch)) X=(X<<)+(X<<)+(ch^),ch=getchar();
return w?-X:X;
}
int find(ll x) {//查找x在HASH表中的位置
int y=x%N,yy=y;bool a=;
while(f[y]!= && f[y]!=x) {//若此位置已经有数并且没有找到这个数
y=(yy*-y+a)%N;
a=!a;
}
if (f[y]==) return y;//判断x在不在hash表
else return -;
}
int main() {
T=read();
while(T--) {//t组数据
memset(f,,sizeof(f));
n=read();
for(int i=; i<=n; i++) {
ll a=read();
z=find(a);
if (z!=-) {//若不在HASH表中,即没有出现过
printf("%lld ",a);//输出它
f[z]=a;//并把它放入HASH表
}
}
puts("");
}
}
[JLOI2011]不重复数字的更多相关文章
- [BZOJ2761][JLOI2011]不重复数字
		[BZOJ2761][JLOI2011]不重复数字 试题描述 给出N个数,要求把其中重复的去掉,只保留第一次出现的数. 例如,给出的数为1 2 18 3 3 19 2 3 6 5 4,其中2和3有重复 ... 
- BZOJ 2761: [JLOI2011]不重复数字 水题
		2761: [JLOI2011]不重复数字 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2100 Solved: 809 题目连接 http:// ... 
- bzoj 2761 [JLOI2011]不重复数字(哈希表)
		2761: [JLOI2011]不重复数字 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 3210 Solved: 1186[Submit][Sta ... 
- 2761: [JLOI2011]不重复数字(平衡树)
		2761: [JLOI2011]不重复数字 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2133 Solved: 825[Submit][Stat ... 
- 2761: [JLOI2011]不重复数字(哈希表)
		2761: [JLOI2011]不重复数字 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1770 Solved: 675[Submit][Stat ... 
- 题解 P4305 【[JLOI2011]不重复数字】
		来一波用vector的最短代码题解 P4305 [JLOI2011]不重复数字 关于hash表的部分大家可以看一看其他的题解,我就不说了 不定长数组vector的几个基本用法: 定义: vector& ... 
- [BZOJ2761] [JLOI2011] 不重复数字 (C++ STL - set)
		不重复数字 题目: 给出N个数,要求把其中重复的去掉,只保留第一次出现的数.例如,给出的数 为1 2 18 3 3 19 2 3 6 5 4,其中2和3有重复,去除后的结果为1 2 1 ... 
- 【BZOJ】2761: [JLOI2011]不重复数字(set+巨水题+超坑题)
		http://www.lydsy.com/JudgeOnline/problem.php?id=2761 太水了,不说了. 但是这格式错误我已经没话说了....行末不能有空格 #include < ... 
- 【bzoj2761】[JLOI2011]不重复数字
		给出N个数,要求把其中重复的去掉,只保留第一次出现的数. 例如,给出的数为1 2 18 3 3 19 2 3 6 5 4,其中2和3有重复,去除后的结果为1 2 18 3 19 6 5 4. Inpu ... 
- [BZOJ2761] [JLOI2011] 不重复数字 (set)
		Description 给出N个数,要求把其中重复的去掉,只保留第一次出现的数. 例如,给出的数为1 2 18 3 3 19 2 3 6 5 4,其中2和3有重复,去除后的结果为1 2 18 3 19 ... 
随机推荐
- P3181 [HAOI2016]找相同字符
			思路 广义SAM 把两个字符串建成广义SAM,然后统计两个SAM中相同节点的endpos大小乘积即可 记得开long long 代码 #include <cstdio> #include ... 
- Linux配置中文输入法(搜狗输入法)
			一.基础知识 在原生ubuntu14.04英文环境系统中只有IBus拼音,真的好难用.由于搜狗输入法确实比Linux系统下其它的中文输入法都要好用得多,所以我决定在我的Ubuntu 14.04系统中安 ... 
- windows(xshell)免密码登录
			windows(xshell)免密码登录 第一步生成密钥文件 打开xshell 选个工具栏的工具如下图 选择密钥类型和长度,如下图 密钥会自动生成,如下图,点击下一步即可 设置给密钥加密的密码也可以不 ... 
- Linux上 发布.Net Core
			环境准备 下面我们使用VM虚拟机.我这里安装的Linux系统是centos7 软件提供: VM: https://www.vmware.com/cn.html centos7 Minimal :htt ... 
- java IO和NIO区别
			面向流与面向缓冲 Java NIO和IO之间第一个最大的区别是,IO是面向流的,NIO是面向缓冲区的. Java IO面向流意味着每次从流中读一个或多个字节,直至读取所有字节,它们没有被缓存在任何地方 ... 
- Bellman-Ford算法模板题
			POJ 3259 虫洞(Bellman-Ford判断有无负环的问题) 描述: 在探索他的许多农场时,Farmer John发现了许多令人惊叹的虫洞.虫洞是非常奇特的,因为它是一条单向路径,在您进入虫洞 ... 
- Spring中使用Redis
			普通使用Redis的方法很简单,前面的文章也有讲解,这篇文章主要就是讲解通过注解的方式实现Spring和Redis的整合.这里我们创建了3个类:1.Config 全局配置类,相当于xml配置文件2.R ... 
- PHP设计模式概念
			设计模式(Design Pattern)是对软件设计中普遍存在(反复出现)的各种问题,所提出的解决方案 设计模式并不直接用来完成代码的编写,而是描述在各种不同情况下,要怎么解决问题的一种方案.面向对象 ... 
- 缺陷管理工具Jira安装参考
			1安装简介 1.1方案/流程简介 需要依赖安装数据库,可以是mysql,orace或sqlserver.以mysql为例说明. 各模块各阶段安装任务说明如下: 安装模块 说明 jira 项目与事务 ... 
- ubuntu18.04.2LTS下安装和配置MySql数据库 --ubuntu
			1.安装MySql ubuntu@thanlon-Ubuntu:~$ sudo apt install mysql-server 2.mysql安装完成后,默认用户名不是root,为了方便,一般我们需 ... 
