poj 1200 Crazy Search(hash)
题目链接:http://poj.org/problem?id=1200
思路分析:从数据来看,该题目使用线性时间算法,可见子串的比较是不可能的;使用hash可以在常数时间内查找,可以常数时间内判重,
可以再线性时间内解决问题;问题关键在与Hash函数的选择,使得子串之间的Hash值不同;由于NC的提示,使用NC作为基数,其他字符
分配不同的数码,从1-NC,再求取Hash值,保证函数为单一映射;
代码如下:
#include <stdio.h>
#include <string.h> const int N = ;
const int MAX_N = ;
int hash[MAX_N];
char A[N];
int value[]; int main( )
{
int N, NC, hashVal, valueKey = ;
int len, ans = , Count = ; memset( value, , sizeof( value ) );
memset( A, , sizeof( A ) );
memset( hash, , sizeof( hash ) );
scanf( "%d %d\n", &N, &NC );
scanf( "%s", A ); len = strlen( A );
for ( int i = ; i < len; ++i )
{
if ( value[A[i]] == )
value[A[i]] = ++valueKey; if ( valueKey == NC )
break;
} for ( int i = ; i + N <= len; ++i )
{
hashVal = ;
for ( int j = i; j < i + N; ++j )
hashVal = hashVal * NC + value[A[j]] - ;
if ( hash[hashVal] == )
{
hash[hashVal] = ;
ans++;
}
} printf( "%d\n", ans );
return ;
}
poj 1200 Crazy Search(hash)的更多相关文章
- POJ 1200 Crazy Search(字符串简单的hash)
		
题目:http://poj.org/problem?id=1200 最近看了一个关于hash的问题,不是很明白,于是乎就找了些关于这方面的题目,这道题是一道简单的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函数有多种形式,但思想都是把 ...
 - [poj1200]Crazy Search(hash)
		
Crazy Search Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 26713 Accepted: 7449 Descrip ...
 - hdu1381 Crazy Search(hash map)
		
题目意思: 给出一个字符串和字串的长度,求出该字符串的全部给定长度的字串的个数(不同样). 题目分析: 此题为简单的字符串哈hash map问题,能够直接调用STL里的map类. map<str ...
 
随机推荐
- Sublime Text3快捷方式总结
			
Ctrl+P快速查找 Ctrl+D多行游标//同时选中多个地方进行编辑 Ctrl+F查找替换 Ctrl+H查找替换 Ctrl+G快速跳到某一行 Ctrl+shift+P命令模式 在命令模式下设置语法: ...
 - result 相关
			
1.dispatcher 2.redirect 3.chain 4.redirectAction 5.freemarker 6.httpheader 7.stream 8.velocity 9.xsl ...
 - C实现二叉树(模块化集成,遍历的递归与非递归实现)
			
C实现二叉树模块化集成 实验源码介绍(源代码的总体介绍):header.h : 头文件链栈,循环队列,二叉树的结构声明和相关函数的声明.LinkStack.c : 链栈的相关操作函数定义.Queue. ...
 - Mac环境下Myeclispe2015工具的安装与破解
			
链接地址:http://www.07net01.com/2015/08/919753.html 07net01.com 发布于 2015-08-30 22:19:37 分类:IT技术 阅读(306) ...
 - If We Were a Child Again
			
Description The Problem The first project for the poor student was to make a calculator that can jus ...
 - Problem A: A + B
			
Problem A: A + BTime Limit: 1 Sec Memory Limit: 128 MBSubmit: 17 Solved: 10[Submit][Status][Web Boar ...
 - JBoss 系列六十九:CDI 基本概念
			
概述 如果说EJB,JPA是之前JEE(JEE5及JEE5之前)中里程碑式的规范,那么在JEE6,JEE7中CDI可以与之媲美,CDI(Contexts and Dependency Injectio ...
 - Mongodb备份(mongodump)和恢复(mongorestore)
			
1.备份: mongodump -d DbName -o /data/backup 2. 恢复: mongorestore -d newDB --drop data/backup/DbName/
 - divmod数字处理函数
			
divmod(a,b)函数 中文说明: divmod(a,b)方法返回的是a//b(除法取整)以及a对b的余数 返回结果类型为tuple 参数: a,b可以为数字(包括复数) 版本: 在python2 ...
 - JDK JRE先保存 后面再整理
			
1. 定义 JRE(Java Runtime Enviroment)是Java的运行环境.面向Java程序的使用者,而不是开发者.如果你仅下载并安装了JRE,那么你的系统只能运行Java程 序.JRE ...