亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? hash.c

?? SVMcfg: Learns a weighted context free grammar from examples. Training examples (e.g. for natural la
?? C
字號(hào):
/* hash.c
 *
 * Hash tables
 *
 * make_hash: returns a new hash table
 * hash_ref: returns the object associated with a key
 * hash_set: inserts an object into a hash table
 * modified version of hash tables in "The C Programming Language", p 144
 */
 
#include <stdlib.h>
#include <string.h>
#include <stdio.h>
#include <assert.h>
#include "mmm.h"
#include "hash.h"

/*
#define MALLOC		malloc
#define CALLOC	 	calloc
#define REALLOC 	realloc
#define FREE		free
*/

/* Preferred hash sizes - primes not close to a power of 2
 * size_t preferred_sizes[] = {7 43 277 1663 10007 60077 360497 2247673 13486051};
 */

#define preferred_size(size)		\
	(size < 21) ? 7 :		\
	(size < 129) ? 43 :		\
	(size < 831) ? 277 :		\
	(size < 4989) ? 1663 :		\
	(size < 30021) ? 10007 :	\
	(size < 180231) ? 60077 :	\
	(size < 1081491) ? 360497 :	\
	(size < 6743019) ? 2247673 :    \
	13486051

HASH make_ ## HASH(size_t initial_size)
{
  HASH ht;
  ht = (HASH) MALLOC(sizeof(struct HASH ## _table));
  ht->tablesize = preferred_size(initial_size);
  ht->size = 0; 
  ht->table = (HASH ## _cell_ptr *)
    CALLOC(ht->tablesize, (size_t) sizeof(HASH ## _cell_ptr));
  return ht;
}   

/* lookup() returns a pointer to the pointer to the hash cell for this key
 * or, if the key is not present in the table, where it ought to be inserted.
 */
static HASH ## _cell_ptr 
*lookup(const HASH ht, const HASH_KEY key, const size_t hashedkey)
{
  HASH ## _cell_ptr	*p  = ht->table + hashedkey%ht->tablesize;
  
  while ( *p && 
	  ((*p)->hashedkey != hashedkey || HASH_KEYNEQ(key, (*p)->key)) )
    p = &((*p)->next);
  
  return p;
}

static void resize_hash_table(HASH ht)
{
  HASH ## _cell_ptr *oldtable = ht->table;
  size_t oldtablesize = ht->tablesize;
  size_t tablesize = preferred_size(ht->size);
  size_t i;
  HASH ## _cell_ptr	p, nextp;
  
  ht->tablesize = tablesize;
  ht->table = (HASH ## _cell_ptr *) 
    CALLOC(tablesize, (size_t) sizeof(HASH ## _cell_ptr));
  
  for (i=0; i<oldtablesize; i++)
    for (p = oldtable[i]; p; p = nextp) {
      nextp = p->next;
      p->next = ht->table[p->hashedkey%tablesize];
      ht->table[p->hashedkey%tablesize] = p;
    }
  
  FREE(oldtable);
}

HASH_VALUE *HASH ## _ref(HASH ht, HASH_KEY key)
{
  HASH ## _cell_ptr *p = lookup(ht, key, KEY_HASH(key));
  return (*p) ? (*p)->data : NULL;
}

HASH_VALUE *HASH ## _set(HASH ht, HASH_KEY key, HASH_VALUE value)
{
  void *olddata = NULL_VALUE;
  size_t hashedkey = KEY_HASH(key);
  HASH ## _cell_ptr *p = lookup(ht, key, hashedkey);

  if (!*p) {
    if (ht->size++ >= 3*ht->tablesize) {
      resize_hash_table(ht);
      p = lookup(ht, key, hashedkey);
      assert(!*p);
    }
    *p = MALLOC(sizeof(struct HASH ## _cell));
    (*p)->next = NULL;
    (*p)->hashedkey = hashedkey;
    (*p)->key = KEY_COPY(key);
  }
  else 
    olddata = (*p)->data;
  
  (*p)->data = data;
  return olddata;
}

HASH_VALUE HASH ## _inc(HASH ht, HASH_KEY key, HASH_VALUE inc)
{
  size_t hashedkey = KEY_HASH(key);
  HASH ## _cell_ptr *p = lookup(ht, key, hashedkey);
  
  if (!*p) {
    if (ht->size++ >= 3*ht->tablesize) {
      resize_hash_table(ht);
      p = lookup(ht, key, hashedkey);
      assert(!*p);
    }
    *p = MALLOC(sizeof(struct HASH ## _cell));
    (*p)->next = NULL_VALUE;
    (*p)->hashedkey = hashedkey;
    (*p)->key = KEY_COPY(key);
    (*p)->data = NULL_VALUE;
  }

  (*p)->data += inc;
  return (*p)->data;
}

HASH_VALUE *HASH ## _delete(HASH ht, HASH_KEY key)
{
  HASH_VALUE olddata = NULL_VALUE;
  HASH ## _cell_ptr *p = lookup(ht, key, KEY_HASH(key));

  if (*p) {
    olddata = (*p)->data;
    *p = (*p)->next;
    KEY_FREE((*p)->key);
    FREE(*p);
    
    if (--ht->size < ht->tablesize/5)
      resize_hash_table(ht);
  }
  return olddata;
}

void free_ ## HASH(HASH ht)
{
  HASH ## _cell_ptr p, q;
  size_t  i;
  
  for (i = 0; i < ht->tablesize; i++)
    for (p = ht->table[i]; p; p = q) {
      q = p->next;
      KEY_FREE(p->key);
      #ifdef VALUE_FREE
        VALUE_FREE(p->data);
      #endif
      FREE(p);
    }
  FREE(ht->table);
  FREE(ht);
}

/***************************************************************************
 *                                                                         *
 *                           hash iteration                                *
 *                                                                         *
 ***************************************************************************/


HASH ## it HASH ## it_init(HASH ht)
{
  struct HASH ## it hit = { NULL, 0, ht, NULL, 0 };
  return HASH ## it_next(hit);
}

HASH ## it HASH ## it_next(hashlit hit0)
{
  if (hit0.next) {
    struct HASH  ## it hit = { 
      hit0.next->key, hit0.next->data, hit0.ht, 
      hit0.next->next, hit0.index };
    return hit;
  }
  else {
    size_t i = hit0.index;
    size_t tablesize = hit0.ht->tablesize;
    hashl_cell_ptr *table = hit0.ht->table;
    while (i < tablesize && !table[i])
      i++;
    if (i==tablesize) {
      struct hashlit hit = { 0, 0, 0, 0, 0 };
      return hit;
    }
    else {
      struct hashlit hit = {
	table[i]->key, table[i]->data, hit0.ht, table[i]->next, i+1 };
      return hit;
    }}}
	
int hashlit_ok(hashlit hit)
{
  return hit.ht!=NULL;
}


/***************************************************************************
 *                                                                         *
 *                           string stuff                                  *
 *                                                                         *
 ***************************************************************************/
 
/* strhash maps a character string to a hash index < 2^28
 * This is the fn hashpjw of Aho, Sethi and Ullman, p 436.
 */
 
size_t strhash(const char *s)
{
  const char *p;
  unsigned h = 0, g;
  for (p=s; *p != '\0'; p++) {
    h = (h << 4) + (*p);
    if (g = h&0xf0000000) {
      h = h ^ (g >> 24);
      h = h ^ g;
    }}
  return h;
}

char *mystrsave(const char *s)    /* make a duplicate of s; see p 143 */
{
  char *p;
  
  p = (char *) MALLOC(strlen(s)+1);	/* +1 for '\0' */
  strcpy(p, s);
  return p;
}

/***************************************************************************
 *                                                                         *
 *                      string index stuff                                 *
 *                                                                         *
 ***************************************************************************/

/* make_si:  make an si table */
si_t make_si(const size_t initial_size)
{
  key_hash keyhash = (key_hash) &strhash;
  key_neq  keyneq = (key_neq) &strcmp;
  key_copy keycopy = (key_copy) &mystrsave;
  key_free keyfree = (key_free) &FREE;

  MAKE_HASH_BODY(si_t, si_table, hashi_cell_ptr);
  ht->stringsize = 3*ht->tablesize;
  ht->strings = (char **) CALLOC(sizeof(char *), ht->stringsize);
  return ht;
}

/* si_string_index: returns the number associated with string str. */
si_index si_string_index(si_t si, char *string)
{
  size_t hashedstring = (*si->keyhash)(string);
  hashi_cell_ptr *p = (hashi_cell_ptr *) lookup((hash) si, string, hashedstring);
  
  if (!*p) {
    if (si->size >= si->stringsize) {
      resize_hash_table((hash) si);
      p = (hashi_cell_ptr *) lookup((hash) si, string, hashedstring);
      assert(!*p);
      si->stringsize = 3*si->tablesize;
      si->strings = (char **) REALLOC(si->strings, si->stringsize * sizeof(char *));
      assert(si->strings);
    }

    if (si->size > SI_INDEX_MAX) {
      fprintf(stderr, "si_string_index in hash.c; Too many indices, overflows si_index\n");
      exit(2);
    }

    *p = MALLOC(sizeof(struct hashi_cell));
    (*p)->next = NULL;
    (*p)->hashedkey = hashedstring;
    (*p)->key = (*(si->keycopy))(string);
    (*p)->data = si->size;
    si->strings[si->size++] = (*p)->key;
  }
  return((*p)->data);
}

char *si_index_string(si_t si, si_index index) 
{
  assert(index < si->size);
  return si->strings[index];
}

void si_free(si_t si)
{
  size_t i;
  hashi_cell_ptr p, q;
  
  for (i = 0; i < si->tablesize; i++)
    for ( p = si->table[i]; p; p = q) {
      q = p->next;
      (*si->keyfree)(p->key);
      FREE(p);
    }
  FREE(si->table);
  FREE(si->strings);
  FREE(si);
}

void si_display(si_t si, FILE *fp)
{
  size_t i;

  for (i=0; i<si->size; i++) 
    fprintf(fp, "%ld: %s\n", (long) i, si_index_string(si, i));
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一卡二卡三卡| 精品久久久久久久久久久院品网| 日日摸夜夜添夜夜添精品视频| 日韩精品综合一本久道在线视频| 成人免费的视频| 麻豆中文一区二区| 亚洲男人都懂的| 久久久亚洲精品石原莉奈| 欧美唯美清纯偷拍| 99久久伊人久久99| 国产一区二区视频在线播放| 亚洲一区二区视频在线观看| 日本一区二区免费在线| 欧美一卡2卡3卡4卡| 91久久久免费一区二区| 国产成人精品影院| 九九精品一区二区| 丝袜诱惑制服诱惑色一区在线观看 | www.欧美色图| 激情av综合网| 天堂av在线一区| 亚洲一区二区三区不卡国产欧美| 国产精品久久久久久久浪潮网站| 精品女同一区二区| 日韩欧美成人午夜| 欧美精品高清视频| 欧美日韩一区视频| 欧美影视一区二区三区| 色婷婷综合久久久久中文一区二区 | 欧美日韩亚州综合| 91久久一区二区| 在线亚洲人成电影网站色www| 成人午夜大片免费观看| 国产不卡视频一区| 成人毛片视频在线观看| 欧美在线视频日韩| 欧洲色大大久久| 欧美偷拍一区二区| 欧美日韩一区二区三区在线| 欧美日韩美女一区二区| 欧美日韩一区二区三区高清| 欧美日韩国产高清一区二区三区 | 99在线热播精品免费| 成人av在线一区二区| 成人av中文字幕| av欧美精品.com| 91网站在线播放| 在线亚洲免费视频| 欧美挠脚心视频网站| 91精选在线观看| 欧美大片在线观看一区| 欧美精品一区二区三区视频| 久久综合九色综合97婷婷女人 | 欧美日韩美少妇| 日韩欧美一区在线| 久久综合狠狠综合| 国产精品短视频| 亚洲一区二区三区在线播放| 午夜精品国产更新| 激情综合网天天干| 成人免费毛片嘿嘿连载视频| 91激情五月电影| 亚洲图片欧美激情| 亚洲va韩国va欧美va精品| 蜜桃av噜噜一区| 国产成人午夜高潮毛片| 色婷婷亚洲精品| 91精品国产日韩91久久久久久| 精品对白一区国产伦| 国产精品第五页| 亚洲大片一区二区三区| 久久 天天综合| 色综合欧美在线| 日韩欧美一区二区不卡| 国产精品网站在线观看| 亚洲国产一区视频| 极品少妇一区二区| 91麻豆高清视频| 日韩一级大片在线| 最好看的中文字幕久久| 日韩av网站在线观看| 成人黄色av电影| 91超碰这里只有精品国产| ww亚洲ww在线观看国产| 亚洲国产日日夜夜| 国产盗摄一区二区| 欧美精品日韩综合在线| 欧美国产一区视频在线观看| 婷婷综合在线观看| 成人的网站免费观看| 欧美一区二区三区啪啪| 亚洲人被黑人高潮完整版| 久久99精品久久久久久国产越南| 91蝌蚪porny| 久久久精品黄色| 日韩精品一卡二卡三卡四卡无卡| 懂色av一区二区三区蜜臀| 91精品国产麻豆| 一区二区三区影院| 国产不卡免费视频| 最新欧美精品一区二区三区| 精品一区二区三区久久久| 欧美午夜片在线看| 国产精品你懂的在线欣赏| 久久精品国产一区二区三区免费看 | 亚洲欧美一区二区三区孕妇| 久久精品国产色蜜蜜麻豆| 欧美性生活大片视频| 欧美国产乱子伦 | 日韩成人精品在线观看| 91麻豆123| 国产精品视频yy9299一区| 美国毛片一区二区三区| 欧美视频一二三区| 一区二区在线免费| jizzjizzjizz欧美| 中文字幕巨乱亚洲| 国产乱子轮精品视频| 欧美大片免费久久精品三p| 图片区小说区国产精品视频| 91行情网站电视在线观看高清版| 国产精品视频你懂的| 国产成都精品91一区二区三| 久久嫩草精品久久久精品| 麻豆成人免费电影| 欧美一二三区在线| 日韩精品视频网| 在线不卡免费av| 日韩黄色免费电影| 7878成人国产在线观看| 亚洲成人黄色小说| 欧美男人的天堂一二区| 亚洲福利一区二区三区| 欧美日韩一区三区| 亚洲1区2区3区4区| 欧美精品免费视频| 日韩av在线发布| 欧美大片在线观看| 国产精品一级在线| 国产欧美一区视频| 99麻豆久久久国产精品免费优播| 中文字幕亚洲一区二区av在线| 成人av在线影院| 亚洲精品精品亚洲| 欧美日韩国产综合一区二区 | 免费av成人在线| 欧美一级欧美一级在线播放| 男人操女人的视频在线观看欧美| 91精品欧美一区二区三区综合在 | 激情深爱一区二区| 国产性做久久久久久| 播五月开心婷婷综合| 亚洲人成网站色在线观看| 欧美揉bbbbb揉bbbbb| 日韩成人一区二区三区在线观看| 精品美女一区二区三区| 国产 日韩 欧美大片| 亚洲欧洲制服丝袜| 91精品国产91久久久久久一区二区| 蜜臀久久99精品久久久久久9| 精品欧美久久久| 99久久99久久免费精品蜜臀| 亚洲一区在线电影| 日韩精品一区二区三区在线观看 | 日韩高清在线不卡| 久久一区二区三区四区| 99久久99久久精品国产片果冻 | 欧美韩日一区二区三区| 91国产精品成人| 久久精品国内一区二区三区| 国产精品久久免费看| 欧美日韩国产精品成人| 精彩视频一区二区三区| 亚洲欧美一区二区三区极速播放 | 国产成人av一区| 亚洲自拍偷拍欧美| 精品国产一区二区在线观看| 99久久精品国产导航| 麻豆成人av在线| 亚洲三级在线看| 欧美大片免费久久精品三p | 欧美色爱综合网| 国内不卡的二区三区中文字幕 | 91精品视频网| 99国产精品久久久久久久久久久| 亚洲va天堂va国产va久| 中文字幕av一区二区三区高| 欧美猛男男办公室激情| 国产成人免费视频一区| 丝袜美腿成人在线| 亚洲欧洲日韩女同| 精品福利一区二区三区免费视频| 色综合久久综合网| 韩国女主播一区二区三区| 亚洲综合色丁香婷婷六月图片| 久久影院电视剧免费观看| 欧美军同video69gay| 99久久综合精品| 国产成人无遮挡在线视频| 五月天激情综合|