Merge pull request #406 from chatn0ir07/master

Implementet CRC-32 Checksum Algorithm
This commit is contained in:
Hai Hoang Dang 2019-10-13 09:48:23 -07:00 committed by GitHub
commit eee804a896
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 35 additions and 2 deletions

View File

@ -4,4 +4,5 @@ Overview files **hash.h** and **hash.c**
* sdbm
* djb2
* xor8 (8 bit)
* adler_32 (32 bit)
* adler_32 (32 bit)
* crc32 (32 bit)

View File

@ -60,4 +60,28 @@ int adler_32(char s[])
i++;
}
return (b << 16) | a;
}
}
/* crc32 Hash-Algorithm*/
int crc32(char string[])
{
int i = 0;
unsigned int cur_crc, masking;
cur_crc = 0xFFFFFFFF;
while(string[i] != '\0')
{
unsigned int byte = string[i];
cur_crc = cur_crc ^ byte;
for(int j = 8; j > 0; --j)
{
masking = -(cur_crc & 1);
cur_crc = (cur_crc >> 1) ^ (0xEDB88320 & masking);
}
i++;
}
return -cur_crc;
}

View File

@ -40,4 +40,11 @@ char xor8(char[]);
*/
int adler_32(char[]);
/*
crc32: implements the crc-32 hash-algorithm
returns the checksum byte for the passed byte
*/
int crc32(char[]);
#endif

View File

@ -15,6 +15,7 @@ int main(void)
printf("djb2: %s --> %lld\n", s, djb2(s));
printf("xor8: %s --> %i\n", s, xor8(s)); /* 8 bit */
printf("adler_32: %s --> %i\n", s, adler_32(s)); /* 32 bit */
printf("crc32: %s --> %i\n", s, crc32(s));
return 0;
}