这题终于让我AC了,其过程之艰辛我不想再回忆了,看了各种代码,一定要注意指针空和非空的问题,再一个要注意边界。

 #include <stdio.h>
#include <string.h>
#include <math.h>
#include <stdlib.h>
#define mod 9967
int gird[+][];
int K;
int cmp(int a,int b){
int i;
for(i=;i<K;++i){
if(gird[a][i]!=gird[b][i])
return ;
}
return ;
}
void change(int num,int cnt){
int CNT=;
while(num){
gird[cnt][CNT++]=num%;
num=num/;
}
for(int i=;i<K;++i)
gird[cnt][i]+=gird[cnt-][i];
for(int i=;i<K;++i){
gird[cnt][i]-=gird[cnt][];
}
gird[cnt][]=;
return;
}
int sign[mod];
struct node{
node *next;
int pos;
}p[mod];
int main(){
int n,i,j;
int mmax;
int value;
int ttt;
while(~scanf("%d%d",&n,&K)){
memset(gird,,sizeof(gird));
memset(sign,,sizeof(sign));
node *tmp;
node *op;
for(i=;i<mod;++i)
p[i].next=NULL;
mmax=;
p[].next=NULL;
p[].pos=;
sign[]=;
for(i=;i<=n;++i){
scanf("%d",&ttt);
change(ttt,i);
value=;
for(j=;j<K;++j){
value+= ( gird[i][j]*j );
}
value=int(fabs(value))%mod;
if(sign[value]==){
p[value].pos=i;
sign[value]=;
continue;
}else if(sign[value]==){
tmp=(node *)malloc(sizeof(node));
tmp->next=NULL;
tmp->pos=i;
int ss=;
op=&p[value];
while(op!=NULL){
if( cmp(op->pos,i)== ){
ss=;
if( (i-op->pos) > mmax ){
mmax=i- (op->pos);
break;
}
}
op=op->next;
}
if(ss==) continue;
op=&p[value];
while(op->next!=NULL){
op=op->next;
}
op->next=tmp;
}
}
printf("%d\n",mmax);
/*
for(i=0;i<=n;++i){
for(j=0;j<K;++j){
printf("%d ",gird[i][j]);
}
printf("\n");
}
*/ }
return ;
}

poj3274 哈希的更多相关文章

  1. poj3274 找平衡数列(哈希加一点数学思维)

    题目传送门 题目大意:有n只牛,每只牛有k个属性,接下来n个数字,每个数字的二进制位上的1和0分别表示某种属性的有或者无,然后一个特殊数列就是,一个区间内所有牛的各种属性的总和相等(有e种1属性  e ...

  2. POJ-3274 Gold Balanced Lineup---hash经典题!

    题目链接: https://vjudge.net/problem/POJ-3274 题目大意: 给定多头牛的属性,每头牛的属性由一个非负数表示,该数的二进制表示不会超过K位,它的二进制表示的每一位若为 ...

  3. [PHP内核探索]PHP中的哈希表

    在PHP内核中,其中一个很重要的数据结构就是HashTable.我们常用的数组,在内核中就是用HashTable来实现.那么,PHP的HashTable是怎么实现的呢?最近在看HashTable的数据 ...

  4. java单向加密算法小结(2)--MD5哈希算法

    上一篇文章整理了Base64算法的相关知识,严格来说,Base64只能算是一种编码方式而非加密算法,这一篇要说的MD5,其实也不算是加密算法,而是一种哈希算法,即将目标文本转化为固定长度,不可逆的字符 ...

  5. Java 哈希表运用-LeetCode 1 Two Sum

    Given an array of integers, find two numbers such that they add up to a specific target number. The ...

  6. 网络安全——Base64编码、MD5、SHA1-SHA512、HMAC(SHA1-SHA512)哈希

    据说今天520是个好日子,为什么我想起的是502.500.404这些?还好服务器没事! 一.Base64编码 Base64编码要求把3个8位字节(3*8=24)转化为4个6位的字节(4*6=24),之 ...

  7. Oracle 哈希连接原理

    <基于Oracle的sql优化>里关于哈希连接的原理介绍如下: 哈希连接(HASH JOIN)是一种两个表在做表连接时主要依靠哈希运算来得到连接结果集的表连接方法. 在Oracle 7.3 ...

  8. SQL连接操作符介绍(循环嵌套, 哈希匹配和合并连接)

    今天我将介绍在SQLServer 中的三种连接操作符类型,分别是:循环嵌套.哈希匹配和合并连接.主要对这三种连接的不同.复杂度用范例的形式一一介绍. 本文中使用了示例数据库AdventureWorks ...

  9. BZOJ 3555: [Ctsc2014]企鹅QQ [字符串哈希]【学习笔记】

    3555: [Ctsc2014]企鹅QQ Time Limit: 20 Sec  Memory Limit: 256 MBSubmit: 2046  Solved: 749[Submit][Statu ...

随机推荐

  1. C语言sizeof

    一.关于sizeof 1.它是C的关键字.是一个运算符,不是函数: 2.一般用法为sizeof 变量或sizeof(数据类型):后边这种写法会让人误认为是函数,但这种写法是为了防止和C中类型修饰符(s ...

  2. ibatis插入数据后返回自增长的主键

    insert into testTable ( activity_id,activity_title values ( #{activityId,jdbcType=INTEGER}, #{activi ...

  3. iOS应用架构谈:架构设计的方法论

    缘由 之前安居客iOS app的第二版架构大部分内容是我做的,期间有总结了一些经验.在将近一年之后,前同事zzz在微信朋友圈上发了一个问题:假如问你一个iOS or Android app的架构,你会 ...

  4. Pdf 字段加粗相关资料

    http://blog.csdn.net/lx_lhy/article/details/5603073 http://www.codeweblog.com/stag/setfieldproperty- ...

  5. js中使用s(c)标签

    在js或者jquery中使用s标签,其实并不难理解,s标签也只是一个标签而已,当你想象成js+s标签=js+html标签就理解了 例如: <script type="text/java ...

  6. linux内核神级list

    源码: #ifndef _LINUX_LIST_H #define _LINUX_LIST_H /* * Simple doubly linked list implementation. * * S ...

  7. Java SE 第二十四讲----static与final使用陷阱关键字

    1.对于final类型成员变量,一般来说有两种赋值方式: a)在声明final类型的成员变量时就附上初值 package com.cl.staticandfinal; public class Fin ...

  8. javascript闭包的一个例子

    <html> <head> <title>elementFromPoint</title> <script type="text/jav ...

  9. FreeMarker语法知识

    FreeMarker的模板文件并不比HTML页面复杂多少,FreeMarker模板文件主要由如下4个部分组成:1,文本:直接输出的部分2,注释:<#-- ... -->格式部分,不会输出3 ...

  10. 可以获取客户端ip的API

    http://www.ip138.com/ip2city.asp http://www.bliao.com/ip.phtml http://www.whereismyip.com/ http://ww ...