我有一个大小为 4、9、16 或 25 的数组(根据输入),数组中的数字相同但减一(如果数组大小为 9,则数组中的最大元素为8)数字以0开头, 我想做一些算法来为数组生成某种校验和,这样我就可以比较两个数组是否相等,而无需遍历整个数组并逐个检查每个元素。
我在哪里可以得到这样的信息?我需要一些尽可能简单的东西。谢谢你。
编辑:只是为了清楚我想要什么:
-数组中的所有数字都是不同的,因此[0,1,1,2]无效,因为存在重复元素(1)
- 数字的位置很重要,因此 [0,1,2,3] 与 [3,2,1,0] 不同
- 数组将包含数字 0,因此也应考虑到这一点。
编辑:
好的,我尝试在这里实现弗莱彻的算法: http ://en.wikipedia.org/wiki/Fletcher%27s_checksum#Straightforward
int fletcher(int array[], int size){
int i;
int sum1=0;
int sum2=0;
for(i=0;i<size;i++){
sum1=(sum1+array[i])%255;
sum2=(sum2+sum1)%255;
}
return (sum2 << 8) | sum1;
}
老实说,我不知道返回线是做什么的,但不幸的是,该算法不起作用。对于数组 [2,1,3,0] 和 [1,3,2,0] 我得到相同的校验和。
编辑2:
好的,这是另一个,阿德勒校验和 http://en.wikipedia.org/wiki/Adler-32#Example_implementation
#define MOD 65521;
unsigned long adler(int array[], int size){
int i;
unsigned long a=1;
unsigned long b=0;
for(i=0;i<size;i++){
a=(a+array[i])%MOD;
b=(b+a)%MOD;
}
return (b <<16) | a;
}
这也行不通。数组 [2,0,3,1] 和 [1,3,0,2] 生成相同的校验和。我在这里失去了希望,有什么想法吗?