【ACM模板】HASH表(無刪除功能,添查)

來源:互聯網
上載者:User
#include <iostream>#include <cstring>#include <cstdio>#include <cstdlib>#include <algorithm>#include <time.h>using namespace std;const int HASH_SIZE = 1000000;const int HASH_KEY = 17;int next[HASH_KEY][HASH_SIZE];int hash[HASH_SIZE];int origin_nums[HASH_SIZE];int now = 1;int comp(const void *a,const void *b){    return (*(int*) a - *(int*) b );}bool addIntoHash(const int a){    int ind = a % HASH_KEY;    int i = 0;    while( next[ind][i] )    {        if ( hash[ next[ind][i] ] == a )        {            return false;        }        i = next[ind][i];    }    next[ind][i] = now;    hash[now] = a;    now++;    return true;}int main(){    srand(time(NULL));    for(int i = 0 ; i < HASH_SIZE ; i++)    {        origin_nums[i] = rand() % 10000;    }    for(int i = 0 ; i < HASH_SIZE ; i++)    {      //  addIntoHash(5);        addIntoHash(origin_nums[i]);    }    printf("The hash table is \n");    for(int i = 1 ; i < now ; i++)    {        printf("%d ",hash[i]);        if ( i % 10 == 0 ) printf("\n");    }    printf("\n");    qsort(hash,now,sizeof(int),comp);    printf("After sorting\n");    for(int i = 1 ; i < now ; i++)    {        printf("%d ",hash[i]);        if ( i % 10 == 0 ) printf("\n");    }   return 0;}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.