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

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

?? dstate.cpp

?? 我的一個利用有限狀態機的正則表達式的實現。
?? CPP
字號:
#include "DState.h"
#include "MyHash.h"

#include <stdio.h>
#include <stdlib.h>
#include <assert.h>

// macros
#define DEFAULT_DTRAN_SIZE 16

HASH_TABLE* initialize_dstate_hash_table() {
	return new_hash_table();	
}

HASH_TABLE* DSTATE_HASH_TABLE = initialize_dstate_hash_table();

inline size_t get_address_hash_value( void* address ) {

	return (HASH_TABLE_SIZE - 1)&( (size_t) address );

}

HASH_TABLE::LLNode* insert_dstate( HASH_TABLE* hash_table, DSTATE* ds ) {
	
	size_t hash = get_address_hash_value( ds->node_set );

	HASH_TABLE::LLNode* prev = &hash_table->table[hash];
	HASH_TABLE::LLNode* n = prev->next;

	HASH_TABLE::LLNode* new_n = NULL;

	DSTATE* ns = NULL;

	while( n ) {

		ns = (DSTATE*)n->v;

		if( ns->node_set == ds->node_set ) {
			// there is an existing ds, return it
			new_n = n;
			goto END;
		} 

		if( ns->node_set > ds->node_set ) {
			// no same node, insert one
			goto INSERT;			
		}
		
		// goto next
		prev = n;
		n = n->next;
	}

INSERT:
	new_n = (HASH_TABLE::LLNode*) malloc( sizeof(HASH_TABLE::LLNode) );
	new_n->v = ds;
	new_n->next = n;
	prev->next = new_n;
END:
	return new_n;
}

DSTATE* find_dstate( HASH_TABLE* hash_table, SET* s ) {
	size_t hash = get_address_hash_value( s );
	HASH_TABLE::LLNode* n = hash_table->table[hash].next;

	DSTATE* ns = NULL;

	while( n ) {

		ns = (DSTATE*) n->v;

		if ( ns->node_set == s ) {
			return ns;
		}

		if ( ns->node_set > s ) {
			break;
		}
		
		// goto next
		n = n->next;
	}

	return NULL;
}

DSTATE* new_dstate( SET* s ) {
	// create new dstate
	DSTATE* ds = (DSTATE*) malloc(sizeof(DSTATE));
	ds->node_set = s;
	ds->dtrans_count = 0;
	ds->dtrans_size = DEFAULT_DTRAN_SIZE;
	ds->marked = 0;
	ds->end = 0;
	ds->dtrans = (DTRAN**)malloc( sizeof(DTRAN*)*ds->dtrans_size );

	return ds;
}

void release_dstate( void* v ) {
	DSTATE* d = (DSTATE*) v;
	for( size_t i = 0; i < d->dtrans_count; i++ ) {
		free( d->dtrans[i] );	
	}
	free( d );
}

DTRAN* new_dtran( DSTATE* src, DSTATE* tar, char c ) {

	DTRAN* dt = NULL;
	int i = 0, j = src->dtrans_count -1;
	for( ; i <src->dtrans_count; i++ ) {
		dt = src->dtrans[i];
		if ( dt->c == c ) {
			if ( dt->tar == tar ) { return dt; } // found same, return
			if ( dt->tar > tar ) { break; } // insert here
		}
		if ( dt->c > c ) { break; } // insert here		
	}
	
	// null end, max count = size -1
	if( src->dtrans_count == src->dtrans_size ) {
		// enlarge the dtran table
		src->dtrans_size *= 2;
		src->dtrans = (DTRAN**)realloc( src->dtrans, sizeof(DTRAN*)*src->dtrans_size );
	}

	// if insert point is not at end, move tail
	for( ; j >= i; j-- ) {
		src->dtrans[j+1] = src->dtrans[j];
	}

	// insert the dtran
	dt = (DTRAN*) malloc( sizeof(DTRAN) );
	dt->c = c;
	dt->src = src;
	dt->tar = tar;
	src->dtrans[i] = dt;
	src->dtrans_count++;
	
	return dt;
}

DTRAN* find_dtran( DSTATE* ds, char c ) {
	DTRAN* dt = NULL;
	int i = 0;
	for( ; i <ds->dtrans_count; i++ ) {
		dt = ds->dtrans[i];
		if ( dt->c == c ) {
			return dt;
		}
		if ( dt->c > c ) { break; } // there is no dtran for input c
	}
	return NULL;
}

void PrintDTran( DTRAN* dt ) {
	printf("DTRAN: %d\n", dt);
	printf("ACCEPT: %c\n", dt->c );
	printf("FROM %d TO %d\n", dt->src, dt->tar );
	printf("=== DTRAN %d ENDS ===\n", dt );
}

void PrintDState( DSTATE* ds ) {
	printf("DSTATE: %d\n", ds );
	printf("ENDABLE: %s\n", ( ds->end ? "TRUE" : "FALSE" ) );
	printf("Dtran Count: %d\n", ds->dtrans_count );
	for( int i =0; i < ds->dtrans_count; i++ ) {
		printf ("%d\n", ds->dtrans[i]);
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
7777精品伊人久久久大香线蕉 | 秋霞影院一区二区| 国产色综合久久| 中文字幕一区不卡| 蜜桃一区二区三区在线| 国产毛片一区二区| 色av成人天堂桃色av| 欧美日韩高清一区二区三区| 精品粉嫩超白一线天av| 中文字幕中文在线不卡住| 亚洲国产欧美在线| 日日摸夜夜添夜夜添国产精品| 麻豆精品新av中文字幕| 国产69精品久久久久777| 欧美日韩国产一级| 国产欧美久久久精品影院| 亚洲一区二区三区在线| 精品伊人久久久久7777人| 97精品国产露脸对白| 亚洲国产精品激情在线观看| 久久婷婷色综合| 日韩精品成人一区二区在线| 91久久线看在观草草青青| 国产日韩在线不卡| 麻豆成人免费电影| 91精品婷婷国产综合久久竹菊| 亚洲图片欧美综合| 色欧美乱欧美15图片| 亚洲日本在线a| 91亚洲国产成人精品一区二区三| 国产欧美日韩视频在线观看| 国产一区二区三区在线观看精品| 在线成人免费视频| 免费观看在线综合| 欧美v国产在线一区二区三区| 日韩高清一级片| 日韩精品一区二区三区中文精品| 日韩av一区二区在线影视| 欧美一区二区日韩| 捆绑调教美女网站视频一区| 日韩女优视频免费观看| 九九精品一区二区| 久久久三级国产网站| 国产99久久久久久免费看农村| 日本一区二区成人在线| 暴力调教一区二区三区| 日韩理论电影院| 91福利区一区二区三区| 亚洲成人动漫精品| 日韩一区二区三区三四区视频在线观看 | 免费在线观看视频一区| 日韩一区二区免费在线观看| 蜜桃91丨九色丨蝌蚪91桃色| 精品久久久久久久久久久久久久久| 蜜臀av性久久久久蜜臀aⅴ四虎| 精品99一区二区三区| 国产激情视频一区二区三区欧美| 国产精品天美传媒沈樵| 色狠狠av一区二区三区| 日本午夜精品视频在线观看| 久久久久久久久久久电影| 99国产精品一区| 石原莉奈在线亚洲二区| 久久久久99精品一区| 91免费版在线看| 麻豆国产精品777777在线| 中文字幕欧美国产| 欧美视频一区在线| 国产一区二区三区免费| 一区二区三区日本| 久久久久久亚洲综合| 91成人看片片| 国产剧情一区二区三区| 亚洲一区二区三区不卡国产欧美| 欧美videos大乳护士334| 99re8在线精品视频免费播放| 午夜欧美视频在线观看| 欧美激情一区在线| 91精品国产综合久久婷婷香蕉 | 精品99久久久久久| 一本色道久久加勒比精品| 美腿丝袜亚洲综合| 亚洲码国产岛国毛片在线| 欧美大度的电影原声| 色婷婷综合视频在线观看| 国产又粗又猛又爽又黄91精品| 亚洲另类中文字| 国产亚洲福利社区一区| 91精品一区二区三区久久久久久| av午夜一区麻豆| 国产一区999| 日韩av一区二| 亚洲成人www| 亚洲人成伊人成综合网小说| 久久综合九色综合久久久精品综合| 欧美性大战久久久| 99re视频精品| 国产精品夜夜爽| 精品一区二区三区欧美| 亚洲成人午夜影院| 亚洲男人天堂av| 中文字幕国产一区二区| 精品少妇一区二区三区在线视频| 欧美专区在线观看一区| 波波电影院一区二区三区| 国产剧情在线观看一区二区 | 亚洲第一主播视频| 1区2区3区国产精品| 欧美极品xxx| 久久日韩精品一区二区五区| 欧美一级片在线看| 宅男噜噜噜66一区二区66| 91久久精品国产91性色tv| 99久久国产综合精品色伊| www.日韩精品| av男人天堂一区| 91视频免费看| 色婷婷激情综合| 色综合久久精品| 在线观看网站黄不卡| 色视频成人在线观看免| 91丨九色丨蝌蚪富婆spa| 91香蕉视频在线| 欧美性生活影院| 欧美精品三级日韩久久| 日韩视频免费观看高清完整版在线观看| 欧美电影免费观看高清完整版| 欧美高清激情brazzers| 欧美老肥妇做.爰bbww| 欧美一级日韩一级| 国产欧美日韩另类视频免费观看| 欧美国产视频在线| 亚洲精品视频在线观看网站| 亚洲在线观看免费| 麻豆成人免费电影| 成人综合婷婷国产精品久久蜜臀 | 欧美精品一区二区久久久| 久久久久国产精品人| 日韩伦理电影网| 天天色天天操综合| 国产黄人亚洲片| 91视频一区二区三区| 7878成人国产在线观看| 国产三级三级三级精品8ⅰ区| 中文字幕一区二| 日本美女一区二区| 国产风韵犹存在线视精品| 91在线观看视频| 欧美久久久久免费| 国产女同性恋一区二区| 亚洲乱码国产乱码精品精可以看 | 国产精品短视频| 图片区小说区国产精品视频| 国产一区二区三区四区五区美女| 成人少妇影院yyyy| 91精品国产色综合久久| 中文字幕免费一区| 七七婷婷婷婷精品国产| www.亚洲人| 精品国产亚洲一区二区三区在线观看| 中文字幕乱码日本亚洲一区二区 | 国产日韩高清在线| 五月天激情综合网| 成人免费毛片嘿嘿连载视频| 91精品国产入口| 亚洲日本欧美天堂| 韩国欧美国产一区| 7777精品伊人久久久大香线蕉的 | 亚洲综合偷拍欧美一区色| 麻豆精品一区二区| 欧美色综合网站| 国产精品久久久久久妇女6080| 日韩av电影一区| 在线欧美小视频| 中文字幕av不卡| 蜜桃视频一区二区三区| 91久久精品网| 日韩伦理免费电影| 国产成人福利片| 欧美r级在线观看| 日韩av网站在线观看| 欧美视频在线一区| 亚洲黄色尤物视频| av不卡免费在线观看| 国产欧美一区二区精品性色超碰| 日韩va欧美va亚洲va久久| 欧美性做爰猛烈叫床潮| 国产精品不卡在线| 从欧美一区二区三区| 久久网站最新地址| 久久99精品久久久久久| 日韩午夜中文字幕| 亚洲电影中文字幕在线观看| 色域天天综合网| 亚洲欧美日韩久久精品| www.亚洲激情.com| 自拍偷拍国产精品| 91在线云播放| 亚洲视频在线观看一区| 99久精品国产|