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

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

?? seqtree.cpp

?? 數據挖掘中的序列模式挖掘算法clospan的C++實現
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
#include <assert.h>#include "../Global.h"#include "../ProjDB.h"#include "../MemMap.h"#if defined( _PERFORM_COMMON_PREFIX_CHECKING )// Returns a pointer to the start of the SeqNum th sequence of the projected DB.//inline int * GetStartPtr( const struct PROJ_DB *pDB, int SeqNum, int SeqIdx = 0 )inline int * GetStartPtr( const struct PROJ_DB *pDB, int SeqNum, int SeqIdx ){	int * intPtr;	if( SeqIdx >= (*pDB).m_pProjSeq[SeqNum].m_nProjCount )		assert( false );#ifdef DISK_BASED	if( (*pDB).m_pProjSeq[SeqNum].m_nProjCount == 1 )		intPtr = (int*) (*pDB).m_pProjSeq[SeqNum].m_ppSeq;	else		intPtr = (int*) (*pDB).m_pProjSeq[SeqNum].m_ppSeq[SeqIdx];#else	intPtr = (int*) (*pDB).m_pProjSeq[SeqNum].m_ppSeq[SeqIdx];#endif	return intPtr;}// Returns a pointer to the End of the Sequence that starts at StartPtr.inline int * GetEndPtr( int * StartPtr ){	int * TmpPtr;	TmpPtr = StartPtr;	while( *TmpPtr != -2 )		TmpPtr++;	return TmpPtr;}// Returns a pointer to the first frequent item pointed by StartPtr, or after it.// It returns a pointer to -1 for end of itemset, and -2 for end of the sequence.inline int * GetNextItem( int * StartPtr ){#ifdef DISK_BASED	int * DataPtr = StartPtr;	bool InFreqItemSet = false;	while( true )	{		//if( !(*DataPtr == -1 && InFreqItemSet) && *DataPtr < 0 )		if( *DataPtr < 0 )			return DataPtr;		if( (inter[*DataPtr]).count >= gSUP )			return DataPtr;		InFreqItemSet = true;		DataPtr++;	}#else	return StartPtr;#endif}// Returns true is the sequence pointed to by StartPtr has no frequent items.inline bool SeqIsEmpty( int * StartPtr ){	int * Ptr;		Ptr = GetNextItem( StartPtr );	while( *Ptr == -1 )	{		Ptr = GetNextItem( ++Ptr );	}	if( *Ptr == -2 )		return true;	else		return false;}//************************//************************SeqWrap::SeqWrap() { 	Start = NULL; 	Current = Start; 	FirstItemSet = true; 	CurItemSetIsEmpty = true;	StartIsIntra = true;}#if defined( _FIND_MAX_SEQS )SeqWrap::SeqWrap( int * Strt ) #elseinline SeqWrap::SeqWrap( int * Strt ) #endif{ 	FirstItemSet = true; 	Start = Strt;	StartIsIntra = true;	while( true )	{		if( *Start < 0 )		{			StartIsIntra = false;			break;		}		if( (intra[*Start]).count >= gSUP )			break;		Start++;	}	FirstItemSet = StartIsIntra;	Current = Start; }inline int * SeqWrap::GetFirst() { 	Current = Start;	FirstItemSet = StartIsIntra;	CurItemSetIsEmpty = true;	return Current;}inline int * SeqWrap::GetNext(){	if( Current == NULL || *Current == -2 )		return Current;	if( *Current == -1 )	{ 		FirstItemSet = false;		CurItemSetIsEmpty = true;	}	Current++;	while( true )	{		if( *Current == -2 )			return Current;		if( *Current != -1 ) 		{			if( ( !FirstItemSet && (inter[*Current]).count >= gSUP ) ||				( FirstItemSet && (intra[*Current]).count >= gSUP ) )			{				CurItemSetIsEmpty = false;				return Current;			}		} else { //*Current==-1			if( FirstItemSet )			{				FirstItemSet = false;				CurItemSetIsEmpty = true;				return Current;			} else {				if( !CurItemSetIsEmpty )				{					CurItemSetIsEmpty = true;					return Current;				}				CurItemSetIsEmpty = true;			}		}		Current++;	}}inline int * SeqWrap::GetItemSet( int ItemSetNum ){	int tmp = 0;		Current = GetFirst();	if( *Current == -1 )		Current = GetNext();	while( *Current != -2 )	{		if( *Current == -1 )		{			tmp++;			if( tmp == ItemSetNum )				break;		}		Current = GetNext();	}	return Current;	//return GetNext();}void SeqWrap::Print( FILE * aFile ){	int * TmpPtr = NULL;	int * TmpPtr2 = NULL;	fprintf( aFile, " <" );	TmpPtr = GetFirst();	if( TmpPtr!=NULL )		fprintf( aFile, " (" );	while( TmpPtr != NULL && *TmpPtr != -2 )	{		if( *TmpPtr == -1 )		{			TmpPtr2 = GetNext();			if( *TmpPtr2 == -2 )				fprintf( aFile, ") " );			else				fprintf( aFile, ")  (" );			TmpPtr = TmpPtr2;		} else {			fprintf( aFile, " %d ", *TmpPtr );			TmpPtr = GetNext();		}	}	fprintf( aFile, "> " );	fprintf( aFile, "  Support = %d\n", 0 );}#if defined( _FIND_MAX_SEQS )bool SeqWrap::IsEmpty()#elseinline bool SeqWrap::IsEmpty()#endif // defined( _FIND_MAX_SEQS ){		Current = GetFirst();	while( *Current == -1 )	{		Current = GetNext();	}	if( *Current == -2 )		return true;	else		return false;}SeqWrap::~SeqWrap(){}//************************//************************Prefix::Prefix() : SeqWrap(){ 	End = NULL;	NumOfItemSets = 0;	Sup = 0;}inline Prefix::Prefix( int * Strt, int * End ) : SeqWrap( Strt ){ 	NumOfItemSets = 0;	(*this).End = End;	if( Start == End )		{		Start = NULL;		(*this).End = NULL;		NumOfItemSets = 0;	} else {		CalcNumOfItemSets();	}	Sup = 0;}Prefix::Prefix( const struct PROJ_DB * pDB ) : SeqWrap(){//#define GetDBPrefix_PRINT_DEBUG_INFO	int i = 0;	int j = 0;	int JMax = 1;	bool Inter;	SeqWrap * aSeqWrap = NULL;	bool PrefixIsEmpty = true;#ifdef GetDBPrefix_PRINT_DEBUG_INFO	Sequence * aSeq = NULL;	Sequence * tmpSeq = NULL;	static int Cnt = 0;	tmpSeq = new Sequence( pDB );	printf( "  Original Prefix %dth Record ===> ", Cnt++ );	(*tmpSeq).Print();	delete tmpSeq;#endif		End = NULL;	NumOfItemSets = 0;	//Sup = 1;	Sup = 0; 	if( (*pDB).m_nSup > 0 )	{		// Find first none empty sequence.		for( i=0; i<(*pDB).m_nSup; i++ )		{			for( j=0; j < (*pDB).m_pProjSeq[i].m_nProjCount; j++ )			{				aSeqWrap = new SeqWrap( GetStartPtr( pDB, i, j ) );				if( !(*aSeqWrap).IsEmpty() )				{					Start = (*aSeqWrap).GetFirst();					End = GetEndPtr( Start ) - 1;					//TrimPrefix( Start ); //Trim it with itself.					PrefixIsEmpty = false;					#ifdef GetDBPrefix_PRINT_DEBUG_INFO						aSeq = new Sequence( Start, End-Start, 0, true );						printf( "  First Prefix %dth Record ===> ", i+1 );						if( aSeq ) (*aSeq).Print();						printf( "    Real First Start=%d End=%d Size=%d ===> ", Start, End, End-Start );						Print();					#endif					delete aSeqWrap;					break;				}				delete aSeqWrap;			}			if( Start != End )				break;		}	}	if( Start != End )	{		JMax = 1;		if( *(Start) == -1 )			Inter = true;		else			Inter = false;		//for( i++; i<(*pDB).m_nSup; i++ ) // For every seq in DB		for( i; i<(*pDB).m_nSup; i++ ) // For every seq in DB		{			if( !Inter )				JMax = (*pDB).m_pProjSeq[i].m_nProjCount;			//JMax = 1;			for( j=0; j < JMax; j++ )			{				aSeqWrap = new SeqWrap( GetStartPtr( pDB, i, j ) );#ifdef GetDBPrefix_PRINT_DEBUG_INFO				tmpSeq = new Sequence( (*aSeqWrap).GetFirst(), true );				printf( "  %dth Record ===> ", i+1 );				(*tmpSeq).Print();				delete tmpSeq;#endif				if( !(*aSeqWrap).IsEmpty() )				{					TrimPrefix( (*aSeqWrap).GetFirst() );					Sup++;#ifdef GetDBPrefix_PRINT_DEBUG_INFO					if( Start != End )					{						aSeq = new Sequence( Start, End-Start, 0, true );						printf( "     ++++++++++++++++ Remaining prefix is  " );						(*aSeq).Print();						printf( "        +++++Real Start=%d End=%d Size=%d prefix is ", Start, End, End-Start );						Print();					}#endif				}				delete aSeqWrap;				PrefixIsEmpty = IsEmpty();				if( PrefixIsEmpty )					break;			}							if( PrefixIsEmpty )				break;		}	}	//if( Start == End )		if( PrefixIsEmpty )		{		Start = NULL;		End = NULL;		NumOfItemSets = 0;		Sup = 0;	} else {		CalcNumOfItemSets();	}}Prefix::Prefix( const struct mem_map * pDatasetMemMap ) : SeqWrap(){	bool PrefixIsEmpty = true;	int * RecStart;  int * LastAddr = (int*) GetLastAddrOfMap( pDatasetMemMap );		NumOfItemSets = 0;	Sup = 1; 	Start = (int*) GetStartOfMap( pDatasetMemMap );	Start = GetNextItem( Start ); // Get first frequent item.	while( *Start < 0 && Start < LastAddr )		Start = GetNextItem( Start+1 ); // Get first frequent item.	End = Start;	// Find first none empty sequence.	while( End < LastAddr )	{		End = GetEndPtr(Start) - 1;		if( Start != End )			break;		else			Start = GetNextItem( End + 2 );	}	RecStart = GetNextItem( End + 2 );	while( *RecStart < 0 && RecStart < LastAddr )		RecStart = GetNextItem( RecStart + 1 );	if( Start != End )	{		while( RecStart < LastAddr )		{			TrimPrefix( RecStart );			PrefixIsEmpty = IsEmpty();			if( PrefixIsEmpty )				break;			Sup++;			RecStart = GetEndPtr(RecStart) + 1;			while( *RecStart < 0 && RecStart < LastAddr )				RecStart = GetNextItem( RecStart + 1 );		}	}	if( PrefixIsEmpty )		{		Start = NULL;		End = NULL;		NumOfItemSets = 0;		Sup = 0;	} else {		CalcNumOfItemSets();	}}// Returns number of itemsets that have at least one frequent item.// It starts from StartPtr to EndPtr, if EndPtr is NULL it will search till end of the sequence.inline void Prefix::CalcNumOfItemSets(){	//bool LastWasNegOne = false;	int Result = 0;	if( Start==End )	{		NumOfItemSets = 0;		return;	}	Current = GetFirst();	if( End==NULL )	{		while( *Current!=-2 )		{			//LastWasNegOne = ( *Current==-1 );			Current = GetNext();			if( *Current==-1 )				Result++;		}	} else {		while( Current<End )		{			//LastWasNegOne = ( *Current==-1 );			Current = GetNext();			if( *Current==-1 )				Result++;		}	}	//if( LastWasNegOne )	//	Result--;	NumOfItemSets = Result;}// Number of frequent elements plus number of itemset seperators, -1s, but last one.inline int Prefix::Size(){	//bool LastWasNegOne = false;	int tmp = 0;	Current = GetFirst();	while( Current < End && *Current != -2 )	{		//LastWasNegOne = ( *Current==-1 );

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区在线免费播放| 99精品欧美一区二区蜜桃免费| 久久噜噜亚洲综合| 国产亚洲欧美日韩在线一区| 久久综合狠狠综合久久激情| 在线观看欧美日本| 国产a视频精品免费观看| 五月天视频一区| 国产婷婷精品av在线| 波多野结衣中文字幕一区| 亚洲国产乱码最新视频| 国产三级一区二区| 欧美精品久久久久久久多人混战 | 国产精品一区免费视频| 国产精品久久网站| 中文字幕 久热精品 视频在线| 久久网站热最新地址| 日韩一区二区三| 精品视频一区二区三区免费| 久久―日本道色综合久久| 欧美精品v国产精品v日韩精品| 丁香啪啪综合成人亚洲小说| 欧美色综合天天久久综合精品| 精品少妇一区二区三区| 日韩精品专区在线影院观看| 欧美人体做爰大胆视频| 国产亚洲综合av| 午夜精品福利久久久| 国产在线一区观看| 国产麻豆9l精品三级站| 欧美日韩一区二区在线视频| 国产精品久久网站| 亚洲亚洲人成综合网络| 91久久国产最好的精华液| 亚洲欧洲av另类| 激情五月播播久久久精品| 在线视频欧美精品| 日韩一区二区三区四区五区六区| 国产日韩高清在线| 国产伦理精品不卡| 成人免费黄色大片| 精品久久久久久久久久久久久久久| 日韩欧美一区在线观看| 久久99久久久欧美国产| 成人福利视频网站| 亚洲综合丝袜美腿| 丁香啪啪综合成人亚洲小说| 色婷婷综合久久久久中文一区二区| 欧美www视频| 9i在线看片成人免费| 久久久久久久久久久久久夜| 高清shemale亚洲人妖| 欧美日韩精品一二三区| 亚洲成年人影院| 国产成人精品免费在线| 国产成人自拍网| 国产精品久久久一区麻豆最新章节| 欧美亚洲日本一区| 亚洲国产精品黑人久久久| 精品在线视频一区| 国产精品水嫩水嫩| 欧美96一区二区免费视频| 欧美军同video69gay| 日本视频中文字幕一区二区三区| 欧美三级视频在线播放| 亚洲三级在线观看| 欧美三级电影精品| 成人黄色大片在线观看| 一区二区三区四区乱视频| 成人三级在线视频| 亚洲私人黄色宅男| 91国在线观看| 美女一区二区视频| 国产精品久久毛片| 久久亚区不卡日本| 日韩一区二区三区三四区视频在线观看 | 日韩视频免费直播| 日韩精品欧美精品| 国产日韩欧美高清在线| 欧美xxxxx牲另类人与| 91小宝寻花一区二区三区| 激情综合色播五月| 美女性感视频久久| 夜夜嗨av一区二区三区| 日韩欧美久久一区| 91福利视频网站| 91丨九色丨尤物| 高清久久久久久| 久久国产欧美日韩精品| 亚洲精品国久久99热| 国产目拍亚洲精品99久久精品| 日韩亚洲欧美一区| 色综合久久88色综合天天免费| 北条麻妃一区二区三区| 国产+成+人+亚洲欧洲自线| 免费成人你懂的| 亚洲制服欧美中文字幕中文字幕| 久久久美女艺术照精彩视频福利播放| 成人激情免费视频| 欧美日韩精品福利| 一区二区三区小说| 成人欧美一区二区三区1314| 91精品久久久久久久91蜜桃| 91福利国产精品| eeuss鲁片一区二区三区| 亚洲444eee在线观看| 国产精品久久久久影院| 久久婷婷成人综合色| 欧美不卡在线视频| 日韩视频一区二区在线观看| 在线视频综合导航| 9i看片成人免费高清| 欧美体内she精视频| 成人免费观看av| 欧美日韩久久久久久| 欧美日产国产精品| 成人午夜av电影| 捆绑调教一区二区三区| 99久久精品久久久久久清纯| 精品国精品国产| 久久精品久久99精品久久| 97精品视频在线观看自产线路二| 日韩欧美黄色影院| 亚洲一区二区三区中文字幕 | 欧美日韩一级二级| 在线电影国产精品| 久久久久久久久久久黄色| 亚洲美女免费视频| 成人动漫中文字幕| 久久久噜噜噜久噜久久综合| 日韩精品亚洲专区| 欧美日韩国产中文| 亚洲视频一区二区在线观看| 国产成人精品免费一区二区| 欧美一区二区国产| 欧美国产丝袜视频| 狠狠狠色丁香婷婷综合激情| 精品免费一区二区三区| 奇米影视在线99精品| 中文字幕一区二区不卡| 国产精品亚洲成人| 欧美一级日韩一级| 国产欧美日韩不卡| 国产成人免费视频网站高清观看视频| 丁香六月综合激情| 亚洲免费伊人电影| 欧美一区日韩一区| 国产人伦精品一区二区| 成人免费福利片| 日韩美女久久久| 国产午夜精品一区二区三区嫩草| 国产又黄又大久久| 欧美激情一区在线| 日本精品一级二级| 一二三区精品视频| 久久久久国色av免费看影院| 色综合色狠狠综合色| 成人ar影院免费观看视频| 亚洲成av人片一区二区三区| 亚洲欧美日韩人成在线播放| 99精品视频一区| 久久99国产精品免费| 日韩伦理免费电影| 日韩免费高清av| 欧美在线观看视频一区二区| 日韩av一级电影| 亚洲第一在线综合网站| 国产精品国产精品国产专区不片| 国产欧美日韩亚州综合 | 国产精品久久久久久久久果冻传媒| 国产suv精品一区二区三区| 欧美aⅴ一区二区三区视频| 欧美国产激情一区二区三区蜜月| 91黄色激情网站| 一本一本久久a久久精品综合麻豆| 成人av在线资源网| 91蜜桃传媒精品久久久一区二区| 国产老肥熟一区二区三区| 成人国产精品免费观看动漫| 色先锋资源久久综合| 免费成人av资源网| 国产另类ts人妖一区二区| 国产精品一卡二卡| 成人av网站在线观看| 国产精品卡一卡二卡三| 日韩精品一区二区三区在线| 欧美日韩aaa| 久久精品这里都是精品| 久久综合久久鬼色中文字| 一区二区三区久久久| 亚洲精品免费播放| 国产九色sp调教91| 国产成人免费视频网站 | 国产精品亚洲综合一区在线观看| 东方欧美亚洲色图在线| 国产98色在线|日韩| 欧美一区二区三区在线观看视频| 色网站国产精品| 中文字幕一区二区三区在线播放 | 欧美日韩亚洲综合一区|