POJ-1200 Crazy Search,人生第一道hash题!
真是不容易啊,人生第一道hash题竟然是搜博客看题解来的。
题意:给你一个包含m种字符的字符串,求长度为n的不同子串有多少个。
将每个字串化为一个具体的数然后存入数组标记即可,如果重复出现肯定不用再加了。那么怎么化为一个数呢,这里用的方法是先将每个字符对应一个数,然后每个长度为n的子串就有了一个连续的数,将这个数段转化为m进制下的数即可,时间复杂度是O(len)。注意数据范围!
虽然和网上很多代码思路都是一样的,毕竟是自己理解的结晶,日后回过头回顾回顾也是很欣慰的!
const int N=1e7;
const double eps=1e-4;
const double PI=acos(-1.0);
char str[N];
int fuck[256];
bool v[N];
int main()
{
int n,m;
while(~scanf("%d%d%s",&n,&m,str))
{
int len=strlen(str);
memset(fuck,0,sizeof(fuck));
memset(v,false,sizeof(v));
int x=0;
for(int i=0;i<len;i++)
if(!fuck[str[i]]) fuck[str[i]]=x++;
int pow=1,sum=0;
for(int i=1;i<n;i++) pow*=m;
for(int i=0;i<n;i++) sum=sum*m+fuck[str[i]];
int res=0;
if(!v[sum])
{
v[sum]=true;
res++;
}
for(int i=n;i<len;i++)
{
sum-=fuck[str[i-n]]*pow;
sum=sum*m+fuck[str[i]];
if(!v[sum])
{
res++;
v[sum]=true;
}
}
printf("%d\n",res);
}
return 0;
}
POJ-1200 Crazy Search,人生第一道hash题!的更多相关文章
- POJ 1200 Crazy Search(字符串简单的hash)
		
题目:http://poj.org/problem?id=1200 最近看了一个关于hash的问题,不是很明白,于是乎就找了些关于这方面的题目,这道题是一道简单的hash 字符串题目,就先从他入手吧. ...
 - poj 1200 Crazy Search(hash)
		
题目链接:http://poj.org/problem?id=1200 思路分析:从数据来看,该题目使用线性时间算法,可见子串的比较是不可能的:使用hash可以在常数时间内查找,可以常数时间内判重, ...
 - POJ 1200 Crazy Search 【hash】
		
<题目链接> 题目大意: 给定n,nc,和一个字符串,该字符串由nc种字符组成,现在要你寻找该字符串中长度为n的子字符串有多少种. 解题分析: 因为要判重,所以讲这些字符串hash一下,将 ...
 - POJ 1200 Crazy Search【Hash入门】
		
RK法:https://www.cnblogs.com/16crow/p/6879988.html #include<cstdio> #include<string> #inc ...
 - POJ 1200 Crazy Search  字符串的Hash查找
		
第一次涉及HASH查找的知识 对于字符串的查找有很多前人开发出来的HASH函数,比较常用的好像是ELF 和 BKDR. 这道题没想到突破点是在于其nc值,告诉你组成字符串的字母种类. 还有用26进制, ...
 - POJ     1200    Crazy Search    (哈希)
		
题目链接 Description Many people like to solve hard puzzles some of which may lead them to madness. One ...
 - POJ – 1200 Crazy Search
		
http://poj.org/problem?id=1200 #include<iostream> #include<cstring> using namespace std; ...
 - POJ   1200 Crazy Search
		
思路:利用Karp-Rabin算法的思想,对每个子串进行Hash,如果Hash值相等则认为这两个子串是相同的(事实上还需要做进一步检查),Karp-Rabin算法的Hash函数有多种形式,但思想都是把 ...
 - poj 1200 crasy search
		
https://vjudge.net/problem/POJ-1200 题意: 给出一个字符串,给出子串的长度n和给出的字符串中不同字符的个数nc,统计这个字符串一共有多少不同的长度为n的子串. 思路 ...
 
随机推荐
- jQuery属性和样式操作
			
回顾 1. jquery基本使用 <script src="jquery.min.js"></script><script> $(functio ...
 - ES-windos环境搭建(2)
			
下载 打开elasticsearch官网.选择downloads. 选择elasticsearch,并单击Download. 这里我们不选择最新版,而是选择靠前的版本,下拉选择past release ...
 - 大数据freestyle: 共享单车轨迹数据助力城市合理规划自行车道
			
编者按:近年来,异军突起的共享单车极大地解决了人们共同面临的“最后一公里”难题,然而,共享单车发展迅猛,自行车道建设却始终没有能够跟上脚步.幸运的是摩拜单车大量的轨迹数据为我们提供了一种新的思路:利用 ...
 - springMVC中ajax和后台数据格式错误
			
前台ajax: $.ajax("${pageContext.request.contextPath}/hello",// 发送请求的URL字符串. { dataType : &qu ...
 - 电脑公司最新稳定win7系统下载
			
系统来自系统妈:http://www.xitongma.com 系统概述 电脑公司ghost win7 x86(32位)万能装机版集成的软件符合电脑公司及电脑城装机绝大多数人要求及喜好,既大众,又时尚 ...
 - python 相关编码[转]
			
python 相关编码[转] 三篇文章,导航:(一)(二)(三) (一) 怎么避免UnicodeEncodeError: ‘ascii’ codec can’t…类似的错误? 1.首先在py文件头 ...
 - 在一个工程中同时使用Swift和Objective-C
			
Swift 与 Objective-C 的兼容能力使你可以在同一个工程中同时使用两种语言.你可以用这种叫做 mix and match 的特性来开发基于混合语言的应用,可以用 Swfit 的最新特性实 ...
 - 【转】Python 访问 HDFS
			
1.前言 hdfs , Hadoop Distributed File System.Hadoop的分布式文件系统,安全行和扩展性没得说. 访问HDFS的方式有以下几种: 命令行方式:FS Shell ...
 - bootstrap历练实例: 导航元素中禁用的链接
			
对每个 .nav class,如果添加了 .disabled class,则会创建一个灰色的链接,同时禁用了该链接的 :hover 状态, <!DOCTYPE html><html& ...
 - java mongodb 增删改查 工具类
			
package com.jttx.demo; import com.mongodb.*; import com.mongodb.util.JSON; import java.net.Unkno ...