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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? hash-templates.h

?? SVMcfg: Learns a weighted context free grammar from examples. Training examples (e.g. for natural la
?? H
字號:
/* hash-templates.h
 *
 * Hash table code templates.
 *
 * This file defines two macros, which in turn define hash functions
 * of arbitrary objects.
 *
 * HASH_CODE(HASH, HASH_KEY, HASH_VALUE, KEY_HASH, KEY_NEQ, KEY_COPY,  \
 *		  KEY_FREE, NULL_VALUE, VALUE_FREE)
 *   defines a hash package whose function names have the prefix HASH,
 *   and where
 *       HASH_KEY is the type of hash keys
 *       HASH_VALUE is the type of hash values
 *       KEY_HASH is a hash function for the keys
 *       KEY_NEQ returns 0 iff its pair of key arguments are equal
 *       KEY_COPY returns a copy of a key
 *       KEY_FREE frees a key
 *       NULL_VALUE is value returned for an undefined key
 *       VALUE_FREE frees a value
 *
 * HASH_CODE_ADD has the same arguments as HASH_CODE, but defines
 * functions that assume that values can be added in addition to
 * those of HASH_CODE
 *
 * These functions can be `expanded' by macros if desired.
 * IDENTITY and NO_OP are provided as possible expansions.
 */
 
#include <assert.h>
#include "mmm.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

#define IDENTITY(x)	x
#define NO_OP(x)	
#define NEQ(x,y)	((x)!=(y))

#define HASH_EXPAND_LOAD_FACTOR 3
#define HASH_CONTRACT_LOAD_FACTOR 5

#define HASH_CODE(HASH, HASH_KEY, HASH_VALUE, KEY_HASH, KEY_NEQ, KEY_COPY,  \
		  KEY_FREE, NULL_VALUE, VALUE_FREE)			    \
	\
/* HASH_HEADER(HASH, HASH_KEY, HASH_VALUE); */ \
	\
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;	\
}   	\
        \
size_t HASH ## _size(HASH ht) \
{                             \
  return ht->size;            \
}                             \
	\
  	\
static void HASH ## _resize(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 ## _cell_ptr HASH ## _find(HASH ht, const HASH_KEY key) 	\
{ 	\
  size_t hashedkey = KEY_HASH(key);	\
  size_t hashedkeymod = hashedkey%ht->tablesize;	\
  HASH ## _cell_ptr p = ht->table[hashedkeymod];	\
  	\
  while (p && (p->hashedkey != hashedkey || KEY_NEQ(key, p->key)))	\
    p = p->next;	\
	\
  if (p) 	\
    return p;	\
  else {	\
    if (ht->size++ >= HASH_EXPAND_LOAD_FACTOR*ht->tablesize) {	\
      HASH ## _resize(ht);	\
      hashedkeymod = hashedkey%ht->tablesize;	\
    }	\
    p = MALLOC(sizeof(struct HASH ## _cell));	\
    p->hashedkey = hashedkey;	\
    p->key = KEY_COPY(key);	\
    p->value = NULL_VALUE;	\
    p->next = ht->table[hashedkeymod];	\
    ht->table[hashedkeymod] = p;	\
    return p;			\
}}	\
  	\
HASH_VALUE *HASH ## _valuep(HASH ht, const HASH_KEY key)      	\
{	\
  return(&(HASH ## _find(ht, key)->value));	\
}	\
	\
HASH_VALUE HASH ## _ref(const HASH ht, const HASH_KEY key)	\
{	\
  size_t hashedkey = KEY_HASH(key);	\
  HASH ## _cell_ptr p = ht->table[hashedkey%ht->tablesize];	\
	\
  while (p && (p->hashedkey != hashedkey || KEY_NEQ(key, p->key)))	\
    p = p->next;	\
	\
  return p ? p->value : NULL_VALUE;	\
}	\
	\
HASH_VALUE HASH ## _set(HASH ht, HASH_KEY key, HASH_VALUE value)	\
{	\
  HASH ## _cell_ptr p = HASH ## _find(ht, key);	\
  HASH_VALUE oldvalue = p->value;		\
  p->value = value;				\
  return oldvalue;				\
}	\
	\
HASH_VALUE HASH ## _delete(HASH ht, HASH_KEY key)       \
{       \
  HASH_VALUE oldvalue;  \
  size_t hashedkey = KEY_HASH(key);     \
  HASH ## _cell_ptr     *p  = ht->table + hashedkey%ht->tablesize;      \
        \
  while ( *p &&         \
          ((*p)->hashedkey != hashedkey || KEY_NEQ(key, (*p)->key)) )  \
    p = &((*p)->next); \
        \
  if (*p) {     \
    oldvalue = (*p)->value;     \
    *p = (*p)->next;    \
    KEY_FREE((*p)->key);        \
    FREE(*p);   \
        \
    if (--ht->size < ht->tablesize/HASH_CONTRACT_LOAD_FACTOR)   \
      HASH ## _resize(ht);      \
    return oldvalue;    \
  } \
  else \
    return NULL_VALUE; \
}       \
	\
	\
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);	\
      VALUE_FREE(p->value);	\
      FREE(p);	\
    }	\
  FREE(ht->table);	\
  FREE(ht);	\
}	\
	\
/***************************************************************************	\
 *                                                                         *	\
 *                           hash iteration                                *	\
 *                                                                         *	\
 ***************************************************************************/	\
	\
	\
HASH ## it HASH ## it_init(HASH ht)	\
{	\
  struct HASH ## it hit;	\
  hit.next = NULL;		\
  hit.index = 0;		\
  hit.ht = ht;			\
  return HASH ## it_next(hit);	\
}	\
	\
HASH ## it HASH ## it_next(HASH ## it hit0)	\
{	\
  if (hit0.next) {  		\
    hit0.key = hit0.next->key;	\
    hit0.value = hit0.next->value;	\
    hit0.next = hit0.next->next;	\
    return hit0;	\
  }	\
  else {	\
    size_t i = hit0.index;	\
    size_t tablesize = hit0.ht->tablesize;	\
    HASH ## _cell_ptr *table = hit0.ht->table;	\
    while (i < tablesize && !table[i])	\
      i++;	\
    if (i==tablesize) {	\
      hit0.ht = NULL;	\
      return hit0;	\
    }	\
    else {	\
      hit0.key = table[i]->key;	\
      hit0.value = table[i]->value;	\
      hit0.next = table[i]->next;	\
      hit0.index = i+1;	\
      return hit0;	\
    }}}			\
			\
int HASH ## it_ok(HASH ## it hit)	\
{				\
  return hit.ht!=NULL;		\
} 

#define HASH_CODE_ADD(HASH, HASH_KEY, HASH_VALUE, KEY_HASH, KEY_NEQ,    \
		      KEY_COPY, KEY_FREE, NULL_VALUE, VALUE_FREE)       \
								        \
HASH_CODE(HASH, HASH_KEY, HASH_VALUE, KEY_HASH, KEY_NEQ,                \
		KEY_COPY, KEY_FREE, NULL_VALUE, VALUE_FREE)             \
                                                                        \
HASH_VALUE HASH ## _inc(HASH ht, const HASH_KEY key, HASH_VALUE inc)	\
{	                                                                \
/*  size_t hashedkey = KEY_HASH(key); */	\
  HASH ## _cell_ptr p = HASH ## _find(ht, key);	\
  	\
  p->value += inc;	\
  return p->value;	\
} 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91网站视频在线观看| 日韩欧美亚洲一区二区| 欧美群妇大交群中文字幕| 欧美成人r级一区二区三区| 国产精品污污网站在线观看| 日本欧美一区二区| 色88888久久久久久影院按摩| 精品久久国产字幕高潮| 亚洲va天堂va国产va久| 成人白浆超碰人人人人| 26uuu欧美| 人人狠狠综合久久亚洲| 欧洲亚洲精品在线| 中文字幕中文在线不卡住| 久久99精品网久久| 欧美精品在线观看播放| 亚洲激情中文1区| 97久久久精品综合88久久| 久久色.com| 精品一区二区在线免费观看| 91精品国产乱码久久蜜臀| 亚洲国产成人av| 欧美午夜电影网| 亚洲一区在线视频| 在线欧美一区二区| 一区二区三区加勒比av| 色综合 综合色| 一区二区三区中文免费| 99re在线视频这里只有精品| 国产精品入口麻豆九色| 丁香五精品蜜臀久久久久99网站| www国产成人免费观看视频 深夜成人网 | 久久亚洲一区二区三区四区| 奇米影视一区二区三区小说| 91麻豆精品国产91久久久久久久久| 一区二区激情视频| 欧美日韩精品一区二区| 亚洲va欧美va人人爽| 欧美久久久久免费| 九一久久久久久| 久久亚洲欧美国产精品乐播| 丁香天五香天堂综合| 国产精品嫩草99a| 97久久超碰国产精品电影| 一区二区三区在线视频免费| 欧美日韩亚洲综合在线| 日韩av中文字幕一区二区三区| 日韩欧美一级在线播放| 韩国三级电影一区二区| 国产精品入口麻豆原神| 日本乱人伦一区| 天天综合天天综合色| 精品日产卡一卡二卡麻豆| 国产福利一区二区三区| 有坂深雪av一区二区精品| 欧美精品久久天天躁| 精品一区二区av| 中文字幕日韩一区二区| 欧美日韩一区二区三区不卡| 美女视频网站久久| 亚洲欧洲精品一区二区三区| 欧美精品99久久久**| 国产精品一线二线三线| 亚洲一区二区黄色| 国产婷婷色一区二区三区| 色婷婷精品大在线视频| 免费观看久久久4p| 亚洲视频在线观看一区| 日韩欧美久久久| 91久久奴性调教| 国产精品自在在线| 亚洲国产日产av| 国产欧美一区二区三区鸳鸯浴| 日本韩国一区二区三区| 狠狠色狠狠色综合系列| 亚洲午夜免费视频| 久久麻豆一区二区| 欧美精品久久一区| 成人国产精品免费观看动漫| 奇米影视一区二区三区| 专区另类欧美日韩| 久久午夜色播影院免费高清| 欧美性受xxxx黑人xyx| 成人激情图片网| 日本亚洲免费观看| 亚洲在线中文字幕| 国产精品白丝在线| 久久久久久久精| 日韩欧美一区二区不卡| 欧美日韩综合在线免费观看| 91网站在线观看视频| 国产米奇在线777精品观看| 首页国产欧美久久| 亚洲综合视频在线观看| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 免费看日韩精品| 亚洲国产日产av| 亚洲麻豆国产自偷在线| 亚洲国产精品v| 国产婷婷一区二区| ww久久中文字幕| 欧美成人三级电影在线| 日韩一区二区免费在线电影| 欧美日韩电影一区| 欧美综合亚洲图片综合区| 91女人视频在线观看| 91在线视频免费观看| 成人黄色在线网站| 国产91精品一区二区麻豆网站 | 精品一区二区在线视频| 日韩电影在线一区二区| 午夜一区二区三区在线观看| 亚洲一区在线观看免费| 亚洲大型综合色站| 污片在线观看一区二区| 天天av天天翘天天综合网色鬼国产 | 亚洲国产sm捆绑调教视频 | 国产精品污www在线观看| 国产欧美一区二区在线观看| 中文字幕免费在线观看视频一区| 国产日产欧美一区二区三区| 欧美国产亚洲另类动漫| 国产精品萝li| 亚洲激情校园春色| 丝袜亚洲另类欧美综合| 麻豆成人久久精品二区三区小说| 久久精品国产成人一区二区三区| 久久国产尿小便嘘嘘| 国精产品一区一区三区mba视频| 国产麻豆欧美日韩一区| 成人18视频日本| 欧美三级电影网| 欧美电影免费观看完整版| 久久久不卡网国产精品二区| 国产精品欧美一区喷水| 亚洲一区二区免费视频| 蜜臀91精品一区二区三区| 国产精品99久久久久| 99这里只有精品| 欧美放荡的少妇| 久久精品一区蜜桃臀影院| 亚洲日本青草视频在线怡红院 | 久久国产精品色| 国产91丝袜在线播放九色| 欧美在线播放高清精品| 日韩一级欧美一级| 亚洲欧美怡红院| 日本不卡一二三区黄网| 成人av影院在线| 欧美一区二区三区四区五区 | 亚洲成av人片一区二区梦乃| 麻豆成人91精品二区三区| 波多野结衣91| 日韩欧美综合一区| 一区二区中文视频| 捆绑变态av一区二区三区| 99在线热播精品免费| 欧美一级黄色录像| 亚洲欧美激情一区二区| 精品一区二区三区免费| 色呦呦网站一区| 久久久久久久久一| 亚洲午夜在线观看视频在线| 成熟亚洲日本毛茸茸凸凹| 欧美日本在线一区| 亚洲欧洲日韩av| 韩国三级中文字幕hd久久精品| 欧美在线观看视频在线| 中文字幕不卡三区| 久久精品国产亚洲一区二区三区| 在线欧美小视频| 国产精品欧美经典| 国产一区三区三区| 91精品久久久久久久91蜜桃| 亚洲激情六月丁香| 成人午夜视频在线| 久久久影视传媒| 日本欧美韩国一区三区| 欧美日韩亚洲丝袜制服| 亚洲日韩欧美一区二区在线| 懂色av一区二区在线播放| 日韩精品中午字幕| 日韩和欧美的一区| 欧美日韩色一区| 亚洲一区影音先锋| 色天天综合色天天久久| 国产精品全国免费观看高清| 国产成人av一区二区三区在线观看| 日韩一级完整毛片| 免费成人在线网站| 日韩情涩欧美日韩视频| 日韩av电影一区| 777色狠狠一区二区三区| 亚洲第一av色| 在线不卡中文字幕| 午夜精品123| 7777精品伊人久久久大香线蕉经典版下载 | 亚洲成人先锋电影| 欧美日免费三级在线| 午夜日韩在线电影|