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

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

?? remanage.h

?? 編譯課程設(shè)計(jì)
?? H
字號(hào):
// REManage.h: interface for the REManage class.
//
//////////////////////////////////////////////////////////////////////

#if !defined(AFX_REMANAGE_H__5B8C1C6A_7551_4DF0_B01E_1D40C5481F88__INCLUDED_)
#define AFX_REMANAGE_H__5B8C1C6A_7551_4DF0_B01E_1D40C5481F88__INCLUDED_

#if _MSC_VER > 1000
#pragma once
#endif // _MSC_VER > 1000
#include <string>
#include <vector>
#include <queue>
#include <list>
#include <fstream>
using namespace std;

const int OP=0;		//操作符
const int OP_D=1;	//操作數(shù)

typedef class _EDGE
{
public:
	int start;
	char input;
	int end;
	friend bool operator == (const _EDGE& a,const _EDGE& b)
	{
		return (a.start==b.start)&&(a.input==b.input)&&(a.end==b.end);
	}
}EDGE;		//自動(dòng)機(jī)的邊

typedef struct _NFA
{
	int start;
	int end;
}NFA;		//

class REManage  
{
public:
	REManage();
	REManage(string re);
	virtual ~REManage();
	
	//處理新的輸入
	void Process();

	//測(cè)試輸入字符串,判斷能否由生成的DFA識(shí)別
	bool TestString(string str);
	
	//設(shè)置正規(guī)式
	void setRE(string re);

	//設(shè)置NFA
	void setNFA(vector<EDGE> edge,vector<int> start,vector<int> end);

	//設(shè)置DFA
	void setDFA(vector<EDGE> edge,int start,vector<int> end);

	
private:
	//清空所有容器變量
	void clear();

	//輸出處理結(jié)果
	void OutputResult();

	/********************分析RE函數(shù)**********************/
	/*正規(guī)式到NFA的轉(zhuǎn)換*/
	void ProcessREToNFA();

	int state;		//計(jì)數(shù)狀態(tài)
	int type(char re);		//判斷輸入字符的類型: OP,OP_D
	/********************End*****************************/

	/********************RE到NFA轉(zhuǎn)換有關(guān)函數(shù)*************************/
	/*對(duì)單個(gè)輸入字符構(gòu)造相應(yīng)的NFA*/
	void MakeNFA_S(char input,NFA* n,vector<EDGE>& edge);

	/*構(gòu)造某個(gè)NFA的閉包*/
	void MakeNFA_CL(NFA* result,NFA* op,vector<EDGE>& edge);

	/*構(gòu)造兩個(gè)NFA的或運(yùn)算*/
	void MakeNFA_OR(NFA* result,NFA* left,NFA* right,vector<EDGE>& edge);

	/*構(gòu)造兩個(gè)NFA的與運(yùn)算*/
	void MakeNFA_AND(NFA* result,NFA* left,NFA* right,vector<EDGE>& edge);
	/******************************End*******************************/

	/********************************NFA到DFA轉(zhuǎn)換有關(guān)函數(shù)*************************/
	/*NFA到DFA的轉(zhuǎn)換*/
	void ProcessNFAToDFA();

	/*找到集合input的@閉包,結(jié)果保存在集合output中*/
	void Find_NULL_Closure(vector<int> input, vector<int>&output,vector<EDGE> edge);

	/*計(jì)算集合input在輸入為in時(shí)的所能達(dá)到的狀態(tài)集合result*/
	void Move(vector<int> input,char in,vector<int>&result,vector<EDGE> edge);
	/***************************************End***********************************/

	/********************************DFA最小化有關(guān)函數(shù)*************************/
	/*最小化DFA*/
	void MinimizeDFA();

	/*在DFA中當(dāng)初態(tài)為start,輸入為input時(shí),返回終態(tài)*/
	int MovdDFA(int start,char input);

	/*找到輸入終態(tài)end所在的集合*/
	int FindGather(int end,vector<vector<int> > gather);

	/*消除DFA中的無(wú)用狀態(tài)*/
	void RemoveFutility();

	/*合并DFA中的等價(jià)狀態(tài)*/
	void CombineEquality();
	/*************************************End**********************************/
	
	ofstream out;
	
	//正規(guī)式對(duì)應(yīng)的變量
	string re;				//輸入的正規(guī)式
	vector<char> REInput;		//正規(guī)式的輸入符
	bool isREUpdate;		//正規(guī)式是否已更新
	
	//NFA對(duì)應(yīng)的變量
	vector<char> NFAInput;	//NFA的輸入符
	vector<int>	startNFA;	//NFA的起始狀態(tài)集
	vector<int>	endNFA;		//NFA的終態(tài)集
	vector<EDGE> NFA_EDGE;		//構(gòu)造出的NFA的所有邊的集合
	bool isNFAUpdate;		//NFA是否已更新
	
	//DFA對(duì)應(yīng)的變量
	vector<char> DFAInput;	//DFA的輸入符
	int startDFA;			//DFA的起始狀態(tài)
	vector<int> endDFA;		//DFA的終態(tài)集
	vector<int> nonEndDFA;	//DFA的非終態(tài)集	
	vector<EDGE> DFA_EDGE;	//由NFA所構(gòu)造成的DFA的邊的集合
	vector<vector<int> > DFAStateGather;		//DFA中各個(gè)狀態(tài)對(duì)應(yīng)于NFA中的狀態(tài)集
	bool isDFAUpdate;		//DFA是否已更新

	//DFA最小化后對(duì)應(yīng)的變量
	vector<char> miniDFAInput;	//最小化后DFA的輸入符
	int miniStartDFA;			//最小化后DFA的起始狀態(tài)
	vector<int> miniEndDFA;		//最小化后DFA的終態(tài)集
	vector<int> miniNonEndDFA;	//最小化后DFA的非終態(tài)集
	vector<EDGE> MiniDFA_EDGE;	//最小化后DFA中的邊的集合
	vector<vector<int> > miniStateGather;	//最小化后DFA中各個(gè)狀態(tài)對(duì)應(yīng)于初始DFA中的狀態(tài)集
};

#endif // !defined(AFX_REMANAGE_H__5B8C1C6A_7551_4DF0_B01E_1D40C5481F88__INCLUDED_)

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品国产三级国产| 一区二区三区在线观看动漫| 色哟哟亚洲精品| 蜜臀av性久久久久av蜜臀妖精| 久久久久久久久99精品| 欧美日韩国产一级二级| 成人深夜视频在线观看| 麻豆免费精品视频| 一个色综合网站| 中文字幕高清不卡| xfplay精品久久| 欧美精品精品一区| 色哟哟国产精品| 粉嫩aⅴ一区二区三区四区五区| 日本不卡免费在线视频| 一区二区三区.www| 亚洲天堂免费在线观看视频| 国产婷婷一区二区| 亚洲精品在线三区| 日韩三级视频中文字幕| 欧美亚洲禁片免费| 91毛片在线观看| 成人福利视频在线| 国产**成人网毛片九色| 国产原创一区二区| 国产呦萝稀缺另类资源| 久久成人精品无人区| 日韩av一级片| 日本成人在线电影网| 亚洲第一精品在线| 午夜av电影一区| 亚洲高清免费观看| 五月天中文字幕一区二区| 一区二区三区精品视频在线| 一区二区在线观看免费视频播放| 国产精品美女一区二区| 国产女主播在线一区二区| 久久人人爽爽爽人久久久| 2023国产精品自拍| 久久久久久久久99精品| 久久久精品欧美丰满| 久久久影视传媒| 国产亚洲精品精华液| 国产精品天美传媒| 国产精品视频麻豆| 中文字幕一区二区三区在线观看| 欧美国产一区二区| 国产精品网站在线| 亚洲欧洲中文日韩久久av乱码| 亚洲欧美激情一区二区| 亚洲与欧洲av电影| 三级久久三级久久| 美国毛片一区二区三区| 国产精品一色哟哟哟| 9色porny自拍视频一区二区| 99久久免费国产| 欧美在线free| 欧美一区二区三区小说| 日韩一级高清毛片| 久久久久久久久99精品| 亚洲品质自拍视频网站| 午夜伊人狠狠久久| 九九九久久久精品| 成人免费精品视频| 欧美日韩在线播放三区| 精品国产免费久久| 国产精品国产自产拍高清av| 一区二区成人在线观看| 美女爽到高潮91| 成人网在线播放| 欧美日韩一区二区欧美激情| 欧美成人乱码一区二区三区| 中文字幕免费观看一区| 一区二区三区蜜桃| 久久99在线观看| 91在线小视频| 日韩欧美专区在线| 亚洲欧洲av在线| 日本不卡视频一二三区| 成人夜色视频网站在线观看| 欧美午夜一区二区三区| 久久久精品影视| 亚洲中国最大av网站| 国产精品中文字幕日韩精品| 欧美视频在线一区| 久久久久久毛片| 亚洲一区二区3| 国产成人亚洲精品青草天美| 精品视频999| 国产精品美女久久久久久2018| 午夜欧美一区二区三区在线播放| 国产精品12区| 51精品国自产在线| 国产精品国产精品国产专区不蜜| 亚洲福中文字幕伊人影院| 岛国精品在线播放| 日韩欧美一区二区久久婷婷| 1区2区3区精品视频| 国产自产视频一区二区三区| 欧美视频一区二区在线观看| 国产精品视频一区二区三区不卡| 日本美女一区二区| 欧美专区在线观看一区| 国产精品美女久久久久久| 韩日av一区二区| 欧美日韩国产一区二区三区地区| 中文字幕亚洲一区二区av在线 | 色哟哟一区二区在线观看| 欧美videossexotv100| 亚洲狠狠爱一区二区三区| 成人黄页在线观看| 久久久精品一品道一区| 美国欧美日韩国产在线播放| 在线不卡的av| 亚洲色图19p| www.成人在线| 国产偷国产偷精品高清尤物| 国产一区二区三区精品欧美日韩一区二区三区 | 成人欧美一区二区三区小说 | 国产日韩欧美在线一区| 免费成人结看片| 3751色影院一区二区三区| 亚洲一区二区av电影| 色噜噜狠狠一区二区三区果冻| 国产女主播在线一区二区| 国产精品888| 国产欧美精品在线观看| 国产精品一区三区| 26uuuu精品一区二区| 国产综合久久久久影院| 久久天天做天天爱综合色| 九色|91porny| 久久综合久久综合久久| 久久99精品国产91久久来源| 日韩欧美国产综合一区| 亚洲成精国产精品女| 69精品人人人人| 青草国产精品久久久久久| 日韩欧美国产一二三区| 久久99精品国产麻豆婷婷| 精品乱人伦小说| 国产一区二区三区不卡在线观看| 精品国产一区二区三区av性色| 久久99精品久久久久婷婷| 久久蜜桃香蕉精品一区二区三区| 国产精品自拍三区| 国产精品久久久久久久久图文区 | 精品久久久久久久久久久久久久久 | 在线不卡中文字幕播放| 日本不卡在线视频| 精品久久五月天| 国产精品一卡二| 中文字幕制服丝袜成人av| 在线中文字幕不卡| 天天色图综合网| 欧美乱熟臀69xxxxxx| 美女尤物国产一区| 国产偷国产偷精品高清尤物| 91首页免费视频| 亚洲18女电影在线观看| 日韩美女主播在线视频一区二区三区| 久久国内精品视频| 国产精品毛片a∨一区二区三区| 大尺度一区二区| 樱桃视频在线观看一区| 欧美一区二区三区爱爱| 麻豆成人久久精品二区三区红 | 久久久久久久久蜜桃| av一二三不卡影片| 天天亚洲美女在线视频| 欧美精品一区二区精品网| 91视频www| 亚洲电影欧美电影有声小说| 日韩欧美色综合网站| 99久久综合国产精品| 日韩精品成人一区二区三区| 久久久www成人免费毛片麻豆| 99久久国产综合精品麻豆| 奇米影视一区二区三区| 一区精品在线播放| 91精品欧美综合在线观看最新| 国产精品中文字幕欧美| 亚洲电影一区二区| 国产视频不卡一区| 在线不卡a资源高清| 波多野结衣视频一区| 免费在线看成人av| 亚洲美女免费在线| 久久久久久99精品| 欧美丰满美乳xxx高潮www| 成人深夜福利app| 久久精品国内一区二区三区| 亚洲免费av网站| 国产欧美一区二区精品性色| 欧美精品在欧美一区二区少妇| 风间由美一区二区三区在线观看| 日韩一区欧美二区| 亚洲欧美激情插 | 欧美精品九九99久久| eeuss鲁片一区二区三区在线观看|