这题终于让我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. 使用oschina的git服务器

    初始配置 用注册的用户名和邮箱配置git config,这个信息不一定是你在网站注册的内容. git config --global user.name "" git config ...

  2. MyBatis返回主键

    网上给的例子都很简单 , 只要用useGeneratedKey就行了. @Insert({ "INSERT INTO money_record_increasement (id, creat ...

  3. myBatis出现Mapped Statements collection already contains value for

    造成这个问题的原因很多,我遇到的主要是因为 <select id="queryCountfor****" parameterType="java.lang.Inte ...

  4. animateWithDuration 动画的速度选择

    + (void)animateWithDuration:(NSTimeInterval)duration delay:(NSTimeInterval)delay options:(UIViewAnim ...

  5. Java基础-面板组件

  6. 94、EventBus框架 ---- 转载

    EventBus使用之基础 http://blog.csdn.net/yanbober/article/details/45667363 EventBus框架库代码走读  http://blog.cs ...

  7. Javascript同源策略对context.getImageData的影响

    在本机测试HTML5 Canvas程序的时候,如果用context.drawImage()后再用context.getImageData()获取图片像素数据的时候会抛出错:SECURITY_ERR: ...

  8. C# 自定义事件(EventArgs)

    1,自定义事件: public class TextChangeEventArgs : EventArgs {     private string message;     public TextC ...

  9. Selenium 疑问之二:如何使页面滚动条移动到指定元素element的位置处?

    在用selenium做测试时,会遇到需要操作的元素不在当前可视页面中的情况,如果是手工测试,自然很简单,手动拖拽滚动条到目标元素处即可. 那么,selenium如何实现这种情形呢?答案是需要借助Jav ...

  10. 第六届蓝桥杯B组C++试题

    1.  奖券数目 有些人很迷信数字,比如带"4"的数字,认为和"死"谐音,就觉得不吉利. 虽然这些说法纯属无稽之谈,但有时还要迎合大众的需求.某抽奖活动的奖券号 ...