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

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

?? createt.h

?? 超好用的語法語義分析器,希望對諸位有用,簡單實用!
?? H
字號:
#ifndef HEADER_CREATET
#define HEADER_CREATET

#include <iostream>
#include <sstream>
#include <fstream>
#include <string>
#include <vector>
#include "LLTable.h"

typedef vector<vector<char> > Vec;

class First_Follow
{
	vector<string> strToken;//文法表達式
	vector<string> vt;//非終結(jié)符集合
	vector<string> temp;//中間變量
	Vec FIRST;//FIRST集合
	Vec FOLLOW;//FOLLOW集合
public:
	void Init();//初始化
	void first();//求FIRST集合
	void follow();//求FOLLOW集合
	void createTable(Table lltable);//創(chuàng)建表
};

void First_Follow::Init()
{
	ifstream in("a.txt");
	for( string str; getline(in,str); )
		strToken.push_back(str);//從文件中讀出文法存到strToken中
	for( int i = 0; i < strToken.size(); i++)
	{
		int j = 0;
		string s = "";//求非終結(jié)符
		while( strToken[i][j] != '-' )//"->"以前為非終結(jié)符
		{
			s += strToken[i][j];
			j++;
		}
		vt.push_back(s);//存到vt中
	}
	FIRST.resize(vt.size());//設(shè)置大小
	FOLLOW.resize(vt.size());
	FOLLOW[0].push_back('#');//置#于開始符號的FOLLOW集合中
	temp = vt;
}

void First_Follow::first()
{
	int i;
	while( !temp.empty() )
	{
		for( i = 0; i < vt.size(); i++)
		{
			if( temp.back() == vt[i] )
				break;
		}
		if( FIRST[i].size() == 0)//當前FIRST集合為空
		{
			int flag = 0;
			for( int j = vt[i].size() + 2; j < strToken[i].size(); j++)
			{
				if( flag == 0 && ((strToken[i][j] > 'a' && strToken[i][j] < 'z') || 
					strToken[i][j] == '+' || strToken[i][j] == '*' || 
					strToken[i][j] == '(' || strToken[i][j] == ')' ||
					strToken[i][j] == '$'))//是終結(jié)符號,則FIRST(X) = {X}
				{
					FIRST[i].push_back(strToken[i][j]);
				}
				else if( flag == 0 )//為非終結(jié)符號
				{
					string s = "";//存非終結(jié)符
					s += strToken[i][j];
					if( strToken[i][j+1] == '\'')
						s += '\'';
					for( int k = 0; k < vt.size(); k++)
					{
						if( vt[k] == s )//找到該非終結(jié)符的定義
						{
							if( FIRST[k].size() != 0)//FIRST[k]不為空,把FIRST[k]加到FIRST[i]中
							{                        
								for( int m = 0; m < FIRST[k].size(); m++ )
								{
									int flag1 = 0;
									for( int n = 0; n < FIRST[i].size(); n++)
									{
										if( FIRST[i][n] == FIRST[k][m])//判斷要加入的元素是否已經(jīng)存在
										{
											flag1 = 1;//存在標志為置1
											break;
										}
									}
									if( flag1 == 0 || FIRST[k][m] != '$')//不存在,且不為'$'
										FIRST[i].push_back(FIRST[k][m]);
								}
							}
							else//FIRST[k]為空
							{
								temp.push_back(s);//s非終結(jié)符加到向量temp尾部
    							first();
								for( int m = 0; m < FIRST[k].size(); m++ )//把FIRST[k]加到FIRST[i]中
								{
									int flag1 = 0;
									for( int n = 0; n < FIRST[i].size(); n++)
									{
										if( FIRST[i][n] == FIRST[k][m])
										{
											flag1 = 1;
											break;
										}
									}
									if( flag1 == 0 || FIRST[k][m] != '$')
										FIRST[i].push_back(FIRST[k][m]);
								}
							}
							break;
						}
					}
				}
				if( strToken[i][j] == '|')//出現(xiàn)'|'則對應下一個表達式,flag恢復初始值
					flag = 0;
				else
					flag = 1;
			}
		}
		else
			temp.pop_back();//求完FIRST(X)則刪除X
	}
}

void First_Follow::follow()
{
	temp = vt;
	int i;
	for( int i2 = 0; i2 < temp.size(); i2++)
	{
		for( i = 0; i < vt.size(); i++)
		{
			if( temp[i2] == vt[i] )
				break;
		}
		for( int j = 0; j < strToken.size(); j++)
		{
			int k;
			int flag = 0;
			for( k = 3; k < strToken[j].length(); k++)//從文法中找非終結(jié)符vt[i][0]
			{
				if( strToken[j][k] == vt[i][0] )
				{
					if( vt[i].size() == 1 )//為X形式
					{
						if(	strToken[j].length() > k + 1 && strToken[j][k+1] == '\'' )
							continue;//X與X'不相等
						flag = 1;  //匹配后置1
						k++;//指向下一個非終結(jié)符
						break;
					}
					if( vt[i].size() == 2 )//為X'形式
					{
						if( strToken[j].length() > k + 1 && strToken[j][k+1] == '\'')
						{
							k += 2;  //指向下一個非終結(jié)符
							flag = 1;
							break;
						}
					}
				}
			}
			if(flag == 1)//已匹配
			{
				string s = "";  //A后面的字串
				while( k < strToken[j].length() && strToken[j][k] != '|')
				{
					s += strToken[j][k];
					k++;
				}
				if( s.length() == 0 )//s為空,即為B->@A的形式
				{
					if(FOLLOW[j].size() == 0)
					{
						temp.push_back(vt[i]);
						break;
					}
					for( int m = 0; m < FOLLOW[j].size(); m++ )//FOLLOW[j]加入FOLLOW[i]中
					{
						int flag1 = 0;
						for( int n = 0; n < FOLLOW[i].size(); n++)
						{
							if( FOLLOW[i][n] == FOLLOW[j][m])
							{
								flag1 = 1;
								break;
							}
						}
						if( flag1 == 0 )
						{
							FOLLOW[i].push_back(FOLLOW[j][m]);
						}
					}
				}
				else
				{
					if( s.length() == 1 && 
						((s[0] > 'a' && s[0] < 'z') || 
						s[0] == '+' || s[0] == '*' || 
						s[0] == '(' || s[0] == ')' ||
						s[0] == '$'))//s不為空,但是終結(jié)符,F(xiàn)IRST[s]加入FOLLOW[i]中
					{
						FOLLOW[i].push_back(s[0]);
						continue;
					}
					for( int i1 = 0; i1 < vt.size(); i1++)//s為非終結(jié)符
					{
						if( vt[i1] == s )
						{
							int flag2 = 0;
							for( int m = 0; m < FIRST[i1].size(); m++ )//將非'$'FIRST[s]加入到FOLLOW[i]中
							{
								int flag1 = 0;
								if( FIRST[i1][m] == '$' )
									flag2 = 1;
								for( int n = 0; n < FOLLOW[i].size(); n++)
								{
									if( FOLLOW[i][n] == FIRST[i1][m])
									{
										flag1 = 1;
										break;
									}
								}
								if( flag1 == 0 && FIRST[i1][m] != '$')
									FOLLOW[i].push_back(FIRST[i1][m]);
							}
							if( flag2 == 1)//如果'$'屬于FIRST[s],則將FOLLOW[j]加入到FOLLOW[i]中
							{
								if(FOLLOW[j].size() == 0)
								{
									temp.push_back(vt[i]);
								    break;
								}
								for( int m = 0; m < FOLLOW[j].size(); m++ )
								{
									int flag1 = 0;
									for( int n = 0; n < FOLLOW[i].size(); n++)
									{
										if( FOLLOW[i][n] == FOLLOW[j][m])
										{
											flag1 = 1;
											break;
										}
									}
									if( flag1 == 0 )
										FOLLOW[i].push_back(FOLLOW[j][m]);
								}
							}
							break;
						}
					}
				}
			}
		}
	}
}

void First_Follow::createTable(Table lltable)
{
	Init();
	first();  
	follow();
	for(int i = 0; i < FIRST.size(); i++)
	{
		int k  = 3;
		vector<string> t;
		string s = "";
		string str = "";
		for( k = 2; k < strToken[i].length(); k++)
		{
			if( strToken[i][k] == '>')
				break;
		}
		k++;
		for( ; k < strToken[i].length(); k++)//將文法分成更小的表達式
		{
			if( strToken[i][k] == '|')
			{
				t.push_back(s);
				s = "";
				continue;
			}
			s += strToken[i][k];
		}
		t.push_back(s);
		for(int j = 0; j < FIRST[i].size(); j++)
		{
			str = vt[i] + "->";
			int flag = 0;
			for( int m = 0; m < t.size(); m++)//查找表達式
			{
				if( FIRST[i][j] == t[m][0] )
				{
					str += t[m];
					flag = 1;
					break;
				}
			}
			if( flag == 0 )
			{
				str += t[0];
			}
			if( FIRST[i][j] == '$' )
			{
				for( int l = 0; l < FOLLOW[i].size(); l++)
				{//A->@ 加到M[A,a]中 ,a屬于FIRST(@)
					lltable.Insert_Head(str,vt[i],FOLLOW[i][l]);
				}
			}
			if( FIRST[i][j] != '$')//'$'屬于FIRST(@),b屬于FOLLOW(A),把A->@加到M[A,b]中
				lltable.Insert_Head(str,vt[i],FIRST[i][j]);
		}
	}
}

#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲美女在线一区| av动漫一区二区| 男女男精品网站| 亚洲高清在线精品| 午夜a成v人精品| 日本不卡视频在线| 蜜桃精品视频在线| 九一久久久久久| 国产一区二区主播在线| 国产一区视频在线看| 国产毛片精品国产一区二区三区| 国产一区二区三区视频在线播放| 国产乱人伦偷精品视频免下载| 捆绑紧缚一区二区三区视频| 精品一区二区三区在线观看国产| 国产麻豆精品在线| 国产白丝精品91爽爽久久| 成人午夜精品在线| 91丨九色porny丨蝌蚪| 欧美日韩视频一区二区| 欧美日韩国产中文| 欧美成人在线直播| 日韩亚洲欧美成人一区| 久久综合九色综合欧美就去吻 | 欧美精品自拍偷拍动漫精品| 91麻豆精品国产91久久久久久 | 91麻豆文化传媒在线观看| 欧美影片第一页| 91精品国产综合久久久久久久久久| 日韩一区二区三区电影| 中国av一区二区三区| 亚洲精品福利视频网站| 亚洲不卡一区二区三区| 国产一区二区精品久久99| aaa欧美大片| 欧美日本乱大交xxxxx| 久久美女艺术照精彩视频福利播放| 成人免费在线视频| 性欧美疯狂xxxxbbbb| 国产剧情av麻豆香蕉精品| eeuss鲁片一区二区三区在线观看| 日本乱人伦aⅴ精品| 日韩三级在线免费观看| 日本一区二区免费在线 | 久久99深爱久久99精品| caoporn国产一区二区| 欧美性欧美巨大黑白大战| 欧美mv和日韩mv国产网站| 17c精品麻豆一区二区免费| 视频一区视频二区中文字幕| 国产激情精品久久久第一区二区 | 国产一区亚洲一区| 在线一区二区视频| 亚洲精品一区二区在线观看| 亚洲欧美一区二区三区孕妇| 另类小说色综合网站| 99久久er热在这里只有精品66| 4438x亚洲最大成人网| 国产精品天美传媒沈樵| 日韩av中文字幕一区二区三区| 国产成人综合在线| 91精品国产入口在线| 亚洲视频在线观看一区| 国产乱妇无码大片在线观看| 欧美系列一区二区| 国产精品传媒视频| 国内精品国产三级国产a久久| 在线视频你懂得一区| 欧美国产精品劲爆| 青青草国产成人av片免费| 一本到不卡免费一区二区| 久久综合九色综合97_久久久| 午夜在线电影亚洲一区| 色综合久久久久| 欧美激情一区在线观看| 日韩福利电影在线| 日本高清成人免费播放| 国产精品日韩成人| 国内精品伊人久久久久av一坑| 欧美午夜精品久久久久久孕妇 | 国产超碰在线一区| 欧美大胆人体bbbb| 日精品一区二区| 欧美无砖专区一中文字| 伊人婷婷欧美激情| 99精品视频一区| 亚洲国产精品精华液ab| 国产一区二区精品在线观看| 日韩欧美的一区| 日韩国产欧美三级| 欧美日韩激情在线| 亚洲国产综合在线| 91精品1区2区| 一区二区在线观看av| 91麻豆文化传媒在线观看| 中文字幕一区二区视频| 成人国产精品免费观看| 欧美国产禁国产网站cc| 成av人片一区二区| 亚洲欧美一区二区三区孕妇| 色又黄又爽网站www久久| 国产精品久久久久aaaa| www.成人在线| 亚洲精品美腿丝袜| 欧美中文字幕一区二区三区| 亚洲免费av高清| 91久久久免费一区二区| 一区二区三区.www| 欧美精三区欧美精三区| 午夜精品成人在线视频| 91精品综合久久久久久| 麻豆一区二区在线| 久久综合av免费| 懂色av噜噜一区二区三区av| 中文字幕在线观看不卡| 色欧美乱欧美15图片| 亚洲午夜在线观看视频在线| 91精品国产综合久久久蜜臀图片| 久久成人免费网| 久久亚洲综合色| 成人黄色在线视频| 一区二区三区精品在线| 欧美日韩在线不卡| 另类调教123区 | 蜜臀91精品一区二区三区| 日韩一区二区三区四区五区六区| 精品一区二区三区久久久| 欧美国产精品久久| 欧美伊人久久久久久午夜久久久久| 婷婷亚洲久悠悠色悠在线播放| 精品少妇一区二区三区视频免付费 | 欧美一区二区视频网站| 国产一区三区三区| 亚洲免费资源在线播放| 在线播放中文字幕一区| 国产高清在线精品| 亚洲综合激情另类小说区| 91精品国产欧美一区二区成人| 国产精品一区在线观看你懂的| 亚洲三级在线免费| 日韩一区二区三区观看| 成人av在线播放网站| 午夜精品视频一区| 久久久国产精品午夜一区ai换脸| 99久久99久久精品国产片果冻| 亚洲成人免费av| 久久精品亚洲一区二区三区浴池| 91麻豆免费在线观看| 久久精品久久综合| 国产精品的网站| 日韩免费观看高清完整版在线观看| 福利一区在线观看| 日日骚欧美日韩| 国产精品久久久久久久浪潮网站 | 久久久亚洲国产美女国产盗摄 | 欧美亚洲一区二区三区四区| 久久99精品久久久久久国产越南 | 亚洲永久精品国产| 久久蜜桃av一区二区天堂| 在线视频你懂得一区二区三区| 国产一区二区精品久久99| 亚洲午夜久久久久久久久电影网| 久久久久国产精品免费免费搜索| 欧美亚洲国产一卡| 成人精品一区二区三区四区| 日本午夜精品视频在线观看| 亚洲乱码一区二区三区在线观看| 欧美成人高清电影在线| 欧美性生交片4| av成人动漫在线观看| 国产一区欧美二区| 欧美aa在线视频| 夜夜嗨av一区二区三区网页 | 日韩国产精品久久久久久亚洲| 国产精品二区一区二区aⅴ污介绍| 91麻豆精品久久久久蜜臀| 色先锋资源久久综合| 国产成人精品免费一区二区| 日韩av不卡一区二区| 亚洲精品精品亚洲| 欧美激情在线看| 久久久久久久久97黄色工厂| 日韩午夜在线观看视频| 欧美美女网站色| 色久优优欧美色久优优| 丁香六月综合激情| 国产一区二区三区四| 久久国产婷婷国产香蕉| 天堂在线亚洲视频| 亚洲午夜三级在线| 亚洲综合在线免费观看| 中文字幕日韩一区二区| 久久久不卡网国产精品一区| 日韩精品一区二区三区中文精品| 欧美色图激情小说| 欧美系列一区二区| 欧美伊人久久久久久久久影院| 色婷婷久久综合| 色中色一区二区| 色一情一乱一乱一91av|