合肥工业大学编译原理实验报告(完整代码版)
计算机与信息学院
编译原理
实验报告 专
业
班
级
信息安全 131 班
学生姓名及学号
马骏 2013211869
课 程 教 学 班 号
任
课
教
师
李宏芒
实 验 指 导 教 师
李宏芒
实 验 地 点
实验楼机房
2015
~2016
学年第 二 学期 验 实验 1
词法分析设计 一、
实验目得
通过本实验得编程实践,使学生了解词法分析得任务,掌握词法分析程序设 计得原理与构造方法,使学生对编译得基本概念、原理与方法有完整得与清楚得 理解,并能正确地、熟练地运用 二、 实验要求
1、编程时注意编程风格:空行得使用、注释得使用、缩进得使用等。
2、将标识符填写得相应符号表须提供给编译程序得以后各阶段使用。
3、根据测试数据进行测试。测试实例应包括以下三个部分:
全部合法得输入。
各种组合得非法输入。
由记号组成得句子。
4、词法分析程序设计要求输出形式:
例:输入 VC++语言得实例程序:
If i=0 then
n++;
a﹤= 3b %);
输出形式为:
单词
二元序列
类
型
位置(行,列)
(单词种别,单词属性)
for
(1,for )
关键字
(1,1)
i
( 6,i )
标识符
(1,2)
=
( 4,= )
关系运算符
(1,3)
12
0
( 5,0 )
常数
(1,4)
then
( 1,then)
关键字
(1,5)
n
(6,n )
标识符
(1,6)
++
Error
Error
(1,7)
;
( 2, ; )
分界符
(1,8)
a
(6,a )
标识符
(2,1)
﹤=
(4,<= )
关系运算符
(2,2)
3b
Error
Error
(2,4)
%
Error
Error
(2,4)
)
( 2, ) )
分界符
(2,5)
;
( 2, ; )
分界符
(2,6)
三、
实验内容 用 VC++/VB/JAVA 语言实现对 C 语言子集得源程序进行词法分析。通过输 入源程序从左到右对字符串进行扫描与分解,依次输出各个单词得内部编码及单 词符号自身值;若遇到错误则显示“Error”,然后跳过错误部分继续显示 ;同时 进行标识符登记符号表得管理。
以下就是实现词法分析设计得主要工作:
(1)从源程序文件中读入字符。
(2)统计行数与列数用于错误单词得定位。
(3)删除空格类字符,包括回车、制表符空格。
(4)按拼写单词,并用(内码,属性)二元式表示。(属性值——token 得机内 表示)
(5)如果发现错误则报告出错
7
(6)根据需要就是否填写标识符表供以后各阶段使用。
四、实验步骤 1、根据流程图编写出各个模块得源程序代码上机调试。
2、 编制好源程序后,设计若干用例对系统进行全面得上机测试,并通过所设计 得词法分析程序;直至能够得到完全满意得结果。
3、书写实验报告 ;实验报告正文得内容:
功能描述:该程序具有什么功能?
程序结构描述:函数调用格式、参数含义、返回值描述、函数功能;函数 之间得调用关系图。
详细得算法描述(程序总体执行流程图) 。
给出软件得测试方法与测试结果。
实验总结 (设计得特点、不足、收获与体会)。
五、实验 截图
先创建 salary 文件 输入 If i=0 then
n++;
a<= 3b %);
六、 核心代码
#include<iostream> #include<string> #include<fstream> #include <sstream> using namespace std; const char* salaryfile="salary"; const int max=40; string id[max]={"do","end","for","if","printf","scanf","then","while"};// 关键字表 string s[max]={",",";","(",")","[","]","+","","*","/","<","<=","=",">",">=","<>"};// 分界符表 算数运算符表
关系运算符表 string k[max];// 标识符 string ci[max];// 常数 int fjfpoint=5;// 分界符表尾 int mathpoint=9;// 算数运算符表尾 int cipointer=0;// 常数表尾 int idpointer=0;// 关键字表尾 int kpointer=0;// 标识符表尾 int fjf;//0 不就是分界符 1 就是
int rowy=1;// 识别输入行位置 int rowx=1;// 识别输入列位置 int outkey=0;// 打印控制 0 为数字后有字母 其她可以 void searcht(int i,string m)// 根据已识别得首字母识别字符串 { // cout<<"enter searcht!!"<<endl;
int x;
if(i==0)// 首字符就是字母识别关键字
{ //
cout<<" a word!!"<<endl;
for(x=0;x<max;x++)
{
if(id[x]==m)
{
cout<<"(1,"<<id[x]<<")"<<" 字 关 键 字 ("<<rowy<<","<<rowx<<")"<<endl;
break;
}
}
if(x==max)// 不就是关键字再识别标识符
{
for(x=0;x<max;x++)
{
if(k[x]==m)
{
cout<<"(6,"<<m<<") "<<" 符 标 识 符 ("<<rowy<<","<<rowx<<")"<<endl;
break;
}
}
if(x==max)// 标识符表没有时插入标识符
{
cout<<"(6,"<<m<<") "<<" 符 标 识 符 ("<<rowy<<","<<rowx<<")"<<endl;
k[kpointer]=m;
kpointer++;
}
}
}
if(i==1)// 识别常数
{
// cout<<"
a number!!"<<endl;
for(x=0;x<max;x++)
{
if(ci[x]==m)
{
cout<<"(5,"<<x<<")"<<endl;
break;
}
}
if(x==max)
{
cout<<"(5,"<<m<<") 常数 ("<<rowy<<","<<rowx<<")"<<endl;
ci[cipointer]=m;
cipointer++;
}
}
if(i==2)// 识别 分界符 算数运算符
关系运算符
{
// cout<<"
a signal!!"<<endl;
for(x=0;x<max;x++)
{
if(s[x]==m)
break;
}
// x;
if(x<6)
{
fjf=1;
}
if(x>5&&x<10)
{
if(outkey==1)
{
cout<<"(3,"<<s[x]<<") 符 算 数 运 算 符 ("<<rowy<<","<<rowx<<")"<<endl;
outkey=0;
}
fjf=0;
}
if(x>9&&x<max1)
{
if(outkey==1)
{
cout<<"(4,"<<s[x]<<") 符 关 系 运 算 符 ("<<rowy<<","<<rowx<<")"<<endl;
outkey=0;
}
fjf=0;
}
if(x==max)
{
if(outkey==1)
{
cout<<"Error
Error ("<<rowy<<","<<rowx<<")"<<endl;
outkey=0;
}
fjf=0;
}
} }; void wordlook(char t,string sn)// 识别首字符, 分类识别字符串 {
if(t>=48&&t<=57)
searcht(1,sn);
else
{
if((t>64&&t<91)||(t>96&&t<123))
searcht(0,sn);
else searcht(2,sn);
} }; void split(string s)// 分割字符串 { // cout<<s<<endl;
string now[max];
string sn;
int nowpointer=0;
int i=0;
int x;
int sign=2;// 非法数字标志
int diannumber=0;// 数中点得个数
for(x=0;x<s 、length;x++)
{
if((s[x]>64&&s[x]<91)||(s[x]>96&&s[x]<123)||(s[x]>=48&&s[x]<=57)||(x>0&&s[x]==46&&sign==1))// 判断数字后跟字母还就是字母后有数字
{
if(i==0)
{
if(s[x]>=48&&s[x]<=57)
sign=1;
else sign=2;
}
else
{
if(sign==1)
{
if(s[x]>=48&&s[x]<=57||s[x]==46)
{
if(s[x]==46)
{
if(diannumber==0)
diannumber++;
else sign=0;
}
}
else sign=0;
}
}
i++;
if(x==(s 、length1))
{
sn=s 、substr(xi+1,i);
if(i>0)
{
//
cout<<sn<<" i="<<i<<endl;
cout<<sn<<" ";
if(sign==0)// 数字后有字母得情况
cout<<"
Error
Error
("<<rowy<<","<<rowx<<")"<<endl;
else // 字母开头得字符串
{
//
cout<<"
true"<<endl;
wordlook(sn[0],sn);
rowx++;
}
}
}
}
else
{
if(x>0&&(s[x1]>64&&s[x1]<91)||(s[x1]>96&&s[x1]<123)||(s[x1]>=48&&s[x1]<=57))// 遇到分界符运算符 如果前面就是数字或字母
{
sn=s 、substr(xi,i);
if(i>0)
{
//
cout<<sn<<" i="<<i<<endl;
cout<<sn<<" ";
if(sign==0)
cout<<" Error Error ("<<rowy<<","<<rowx<<")"<<endl;
else
{
//
cout<<"
true"<<endl;
wordlook(sn[0],sn);
rowx++;
}
}
i=0;
}
string ll=s 、substr(x,1);// 判断就是运算符还就是分界符
wordlook(s[x],ll);
if(fjf==0)// 就是运算符
{
i++;
if((s[x+1]>64&&s[x+1]<91)||(s[x+1]>96&&s[x+1]<123)||(s[x+1]>=48&&s[x+1]<=57))// 如果后面就 是数字或字母
{
sn=s 、substr(xi+1,i);
// cout<<sn<<" 运算符 i="<<i<<endl;
cout<<sn<<" ";
outkey=1;
wordlook(sn[0],sn);
rowx++;
i=0;
}
}
if(fjf==1)
{
if((s[x1]>64&&s[x1]<91)||(s[x1]>96&&s[x1]<123)||(s[x1]>=48&&s[x1]<=57))// 如 如果前面就是数字或字母
{
}
else if(i>0)
{
sn=s 、substr(xi,i);
// cout<<sn<<" 运算符 i="<<i<<endl;
cout<<sn<<" ";
outkey=1;
wordlook(sn[0],sn);
rowx++;
i=0;
}
cout<<s[x]<<" (2,"<<s[x]<<") 符 分 界 符 ("<<rowy<<","<<rowx<<")"<<endl;
rowx++;
/*
if(ll==";")
{
rowy++;
rowx=1;
}
*/
}
}
} }; int main {
int x;
string instring;// 读入一行
string sn; /*
getline(cin,sn);// string 带空格输入
cout<<sn<<endl;
char t=sn[0];
if(t>=48&&t<=57)
searcht(1,sn);
else
{
if((t>64&&t<91)||(t>96&&t<123))
searcht(0,sn);
else searcht(2,sn);
} */
ifstream input
input(salaryfile); // inputfile>>noskipws;
if(!inputfile)
{
cout<<"no file"<<endl;
}
string pp;
while(!input)
{
getline(input);
istringstream istr(pp);
string ppword;
while(istr>>ppword)// 按照空格分割字符串
{
split(ppword);
} /*
int begin = 0;// 去掉字符串得所有空格
begin = pp 、find(" ",begin);
// 查找空格在 str 中第一次出现得位置
while(begin != 1)
// 表示字符串中存在空格
{
pp 、replace(begin, 1, "");
// 用空串替换 str 中从 begin 开始得 1 个字符 符
begin = pp 、find(" ",begin);
// 查找空格在替换后得 str 中第一次出现得位置
}
*/ // cout<<"good
"<<pp<<endl; // rowx++;
rowy++;// 换行
rowx=1;
}
return 0; } 七、 实验总结
通过本次试验使我不仅对词法分析器有了更深得了解,而且提高了编程能力,希望在以后得学习中可以解决词法分析更多得问题。
验 实验 2
LL(1) 分析法
一、 实验目得 通过完成预测分析法得语法分析程序,了解预测分析法与递归子程序法得区 别与联系。使学生了解语法分析得功能,掌握语法分析程序设计得原理与构造方 法,训练学生掌握开发应用程序得基本方法。有利于提高学生得专业素质,为培 养适应社会多方面需要得能力。
二、 实验要求 1、编程时注意编程风格:空行得使用、注释得使用、缩进得使用等。
2、如果遇到错误得表达式,应输出错误提示信息。
3、对下列文法,用 LL(1)分析法对任意输入得符号串进行分析:
(1)E>TG
(2)G>+TG|—TG
(3)G>ε
(4)T>FS
(5)S>*FS|/FS
(6)S>ε
(7)F>(E)
(8)F>i
三、 实验内容 根据某一文法编制调试
LL (
1 )分析程序,以便对任意输入得符号串 进行分析。
构造预测分析表,并利用分析表与一个栈来实现对上述程序设计语言得分 析程序。
分析法得功能就是利用 LL(1)控制程序根据显示栈栈顶内容、向前瞧符号 以及 LL(1)分析表,对输入符号串自上而下得分析过程。
四、实验步骤
1、根据流程图编写出各个模块得源程序代码上机调试。
2、 编制好源程序后,设计若干用例对系统进行全面得上机测试,并通过所设计 得 LL(1)分析程序;直至能够得到完全满意得结果。
3、书写实验报告 ;实验报告正文得内容:
写出 LL(1)分析法得思想及写出符合 LL(1)分析法得文法。
程序结构描述:函数调用格式、参数含义、返回值描述、函数功能;函数 之间得调用关系图。
详细得算法描述(程序执行流程图) 。
给出软件得测试方法与测试结果。
实验总结 (设计得特点、不足、收获与体会)。
五、实验 截图
六、 核心代码
#include<iostream> #include<string> using namespace std; string pp;// 输出字符串 string hh="\r\n";// 换行 const int max=50; int endfu[max];// 终止符序号表 int endfupointer=8; char endfureal[max]={"+","","*","/","(","i",")","#"}; int unendfu[max]; int unendfupointer=5; char unendfureal[max]={"E","G","T","S","F"}; string makemath[max]={"E>TG","G>+TG","G>TG","G>$","T>FS","S>*FS","S>/FS","S>$","F>(E)","F>i"}; //0 E>TG,1 G>+TG,2 G>TG,3 G>$,4 T>FS,5 S>*FS,6 S>/FS,7 S>$,8 F>(E),9 F>i //$ 代表空串 string behavior[max]={" 初始化","POP"}; int smarttable[max][max];// 分析表 int checkendfu(char fu)// 查终结符序号 {
int x;
for(x=0;x<endfupointer;x++)
{
if(endfureal[x]==fu)
{
break;
}
}
if(x<endfupointer)
return x;
else return 1; }; int checkunendfu(char fu)// 查非终结符序号 {
int x;
for(x=0;x<unendfupointer;x++)
{
if(unendfureal[x]==fu)
break;
}
if(x<unendfupointer)
return x;
else return1; }; string checkmakemath(int x)// 查产生式表 {
return makemath[x]; }; int checksmarttable(int x,int y)// 查分析表 {
return smarttable[x][y]; }; class smartbox { public:
smartbox
{
box[0]="#";
box[1]="E";
boxpointer=1;
}
void push(char fu)
{
boxpointer++;
box[boxpointer]=fu;
}
char pop
{
char a=box[boxpointer];
if(a!="#")
{ //
cout<<"pop: "<<boxpointer<<"
"<<a<<endl; //
stringstream oss; /*
pp=pp+"pop: ";
char buffer[max];
sprintf(buffer,"%d",boxpointer);
string s=buffer;
pp=pp+" ";
pp=pp+s;
pp=pp+hh; */
boxpointer;
return a;
}
}
void check
{
if(checkendfu(box[boxpointer])!=1)
{
char a; //
cout<<box[boxpointer]<<checkendfu(box[boxpointer])<<"
";
//char buffer[max];
//sprintf(buffer //
pp=pp+box[boxpointer];
// pp=pp+checkendfu(box[boxpointer]); //
pp=pp+"
";
a=pop;
// cout<<"out "<<a<<endl;
}
}
char box[max];
int boxpointer; }; int main {
// TODO: Add extra validation here // pp=pp+" 步骤
分析栈
剩余输入串
所用产生式
动作"+hh; /*
string s1="sdsfs
\r\nsdfsds";
string s3="aaaaaaaaaaaaa";
s3=s3+s1;
CString s2(s3 、c_str); // CString s2=CString(s1);
SetDlgItemText(IDC_EDIT2,s2);// 用 SetDlgItemText( 文本框 ID, 字符串), 将文本框得内容设置为字符串得内容、
SetDlgItemText(IDC_EDIT2,s2); */ // MessageBox(str); string str; cin>>str;
int x,y;
for(x=0;x<max;x++)
// 初始化分析表 99 为错误代号
for(y=0;y<max;y++)
smarttable[x][y]=99;
smarttable[0][4]=0;
smarttable[0][5]=0;
smarttable[1][0]=1;
smarttable[1][1]=2;
smarttable[1][6]=3;
smarttable[1][7]=3;
smarttable[2][4]=4;
smarttable[2][5]=4;
smarttable[3][0]=7;
smarttable[3][1]=7;
smarttable[3][2]=5;
smarttable[3][3]=5;
smarttable[3][6]=7;
smarttable[3][7]=7;
smarttable[4][4]=8;
smarttable[4][5]=9;
smartbox mark;
char fu;
char enterfu;
int endfunumber;
int unendfunumber;
string readyin;
string enter; // cin>>enter;
//enter="i+i*i#";
enter=str; //enter="(i)#";
int count=0; // 步骤
char buffer1[max];
sprintf(buffer1,"%d",count);
string s1=buffer1;
pp=pp+s1+"
";
// 分析栈
for(int qq1=0;qq1<=mark 、boxpointer;qq1++)
{
pp=pp+mark 、box[qq1];
}
for(qq1=0;qq1<10mark 、boxpointer;qq1++)
{
pp=pp+" ";
}
// 剩余输入栈
string jiequ1=enter 、substr(0,enter 、length);
pp=pp+jiequ1;
for(int t1=0;t1<20;t1++)
{
pp=pp+" ";
}
pp=pp+"
初始化"+hh;
for(x=0;x<enter 、length;)
{
// 步骤
count++;
char buffer[max];
sprintf(buffer,"%d",count);
string s=buffer;
pp=pp+s+"
";
// 分析栈
for(int qq=0;qq<=mark 、boxpointer;qq++)
{
pp=pp+mark 、box[qq];
}
for(qq=0;qq<10mark 、boxpointer;qq++)
{
pp=pp+" ";
}
// 剩余输入栈
string jiequ=enter 、substr(x,enter 、lengthx);
pp=pp+jiequ;
for(int t=0;t<x+10;t++)
{
pp=pp+" ";
}
enterfu=enter[x];
// cout<<"enterfu: "<<enterfu<<endl;
mark 、check;
fu=mark 、pop; //
cout<<"fu: "<<fu<<endl;
if(fu=="#")//&&enterfu=="#")
{
//
cout<<"sucessed!!!!
over!!!!"<<endl;
pp=pp+"sucessed!!!!
over!!!!"+hh;
break;
}
unendfunumber=checkunendfu(fu);
endfunumber=checkendfu(enterfu);
// cout<<unendfunumber<<endl;
// cout<<endfunumber<<endl;
if(smarttable[unendfunumber][endfunumber]==99)
{
pp=pp+"error!!";
break;
}
readyin=makemath[smarttable[unendfunumber][endfunumber]];
pp=pp+readyin;
for(int ddd=0;ddd<14readyin 、length;ddd++)
{
pp=pp+" ";
}
pp=pp+"POP,PUSH(";
for(y=readyin 、length1;y>2;y)
{
pp=pp+readyin[y];
}
pp=pp+")"+hh;
// cout<<"readyin:
"<<readyin<<endl;
int firsttime=0;
for(y=readyin 、length1;y>2;y)
{
// cout<<readyin[y]<<" ";
if(readyin[y]!="$")
{
mark 、push(readyin[y]);
if(firsttime==0)
{
if(checkendfu(readyin[y])!=1)
{
//
cout<<"now x: "<<x<<"
";
// 步骤
count++;
char buffer[max];
sprintf(buffer,"%d",count);
string s=buffer;
pp=pp+s+"
";
// 分析栈
for(int qq=0;qq<=mark 、boxpointer;qq++)
{
pp=pp+mark 、box[qq];
}
for(qq=0;qq<10mark 、boxpointer;qq++)
{
pp=pp+" ";
}
// 剩余输入栈
string jiequ=enter 、substr(x,enter 、lengthx);
pp=pp+jiequ;
for(int t=0;t<x+10;t++)
{
pp=pp+" ";
}
pp=pp+"
GETNEXT(I)"+hh;
x++;
//
cout<<"next x: "<<x<<"
"<<endl;
firsttime=1;
}
}
}
}
mark 、check;
// cout<<endl; //
pp=pp+hh;
} cout<<pp; return 0;
//CDialog::OnOK; } 七、 实验总结
通过本次试验使我不仅对 ll(1)分析法有了更深得了解,而且提高了编程能力,希望在以后得学习中可以解决自动构造 follow 集得问题。
实验 3
LR(1) 分析法
一、 实验目得 构造 LR(1)分析程序,利用它进行语法分析,判断给出得符号串就是否为该文 法识别得句子,了解 LR(K)分析方法就是严格得从左向右扫描,与自底向上得 语法分析方法。
二、 实验要求 1、编程时注意编程风格:空行得使用、注释得使用、缩进得使用等。
2、如果遇到错误得表达式,应输出错误提示信息。
3、程序输入/输出实例:
输入一以#结束得符号串(包括+*i#):在此位置输入符号串
输出过程如下:
步骤
状态栈
符号栈
剩余输入串
动 作
1
0
#
i+i*i#
移进
i+i*i 得 LR 分析过程
步骤
状态栈
符号栈
输入串
动作说明
1
0
#
i+i*i#
ACTION[0,i]=S5,状态 5 入栈
2
05
#i
+i*i#
r6: F→i 归约,GOTO(0,F)=3 入栈
3
03
#F
+i*i#
r4: T→F 归约,GOTO(0,T)=3 入栈
4
02
#T
+i*i#
r2: E→T 归约,GOTO(0,E)=1 入栈
5
01
#E
+i*i#
ACTION[1,+]=S6,状态 6 入栈
6
016
#E+
i*i#
ACTION[6,i]=S5,状态 5 入栈
7
0165
#E+i
*i#
r6: F→i 归约,GOTO(6,F)=3 入栈
8
0163
#E+F
*i#
r4: T→F 归约,GOTO(6,T)=9 入栈
9
0169
#E+T
*i#
ACTION[9,*]=S7,状态 7 入栈
10
01697
#E+T*
i#
ACTION[7,i]=S5,状态 5 入栈
11
016975
#E+T*i
#
r6:F→i 归约,GOTO(7,F)=10 入栈
12
0169710
#E+T*F
#
r3: T→T*F 归约,GOTO(6,T)=9 入栈
13
0169
#E+T
#
r1:E→E+T,GOTO(0,E)=1 入栈
14
01
#E
#
Acc:分析成功
三、 实验内容 对下列文法,用 LR(1)分析法对任意输入得符号串进行分析:
(1)E> E+T
(2)E>T
(3)T> T*F
(4)T>F
(5)F> (E)
(6)F> i
四、实验步骤 1、根据流程图编写出各个模块得源程序代码上机调试。
2、编制好源程序后,设计若干用例对系统进行全面得上机测试,并通过所设计 得 LR(1)语法分析程序;直至能够得到完全满意得结果。
3、书写实验报告 ;实验报告正文得内容:
描述 LR(1)语法分析程序得设计思想。
程序结构描述:函数调用格式、参数含义、返回值描述、函数功能;函数
之间得调用关系图。
详细得算法描述(程序执行流程图) 。
给出软件得测试方法与测试结果。
五、实验 截图
六、 核心代码 #include<iostream> #include<string> using namespace std; int count=1; string pp;// 输出字符串 string hh="\r\n";// 换行 const int max=100; char endfureal[max]={"i","+","*","(",")","#","E","T","F"}; int endfupointer=8; string creatword[max]={"E>E+T","E>T","T>T*F","T>F","F>(E)","F>i"}; //(0)E> E+T(1)E>T (2)T> T*F (3)T>F (4)F> (E) (5)F> i
// 注意 rj 时 时 j 应对应数组下标 int checkendfu(char fu)// 查终结符序号 {
int x;
for(x=0;x<=endfupointer;x++)
{
if(endfureal[x]==fu)
{
break;
}
}
if(x<=endfupointer)
return x;
else return 1; }; class actiongo// 原子动作 { public:actiongo
{
// cout<<"eroor! wrong action or goto creat"<<endl;
actype=4;
}
action(int i,int j)
{
actype=i;
number=j;
//
cout<<i<<" "<<j<<endl;
}
int actype;//0=s 1=r 2=acc 3=goto 表 4=wrong
int number; }; actiongo smarttable[max][max]; class stylebox// 状态栈 { public:
stylebox
{
box[0]=0;
boxpointer=0;
}
void push(int style)
{
boxpointer++;
box[boxpointer]=style;
}
int pop
{
int a=box[boxpointer];
boxpointer; //
cout<<"pop now"<<endl;
return a;
}
int box[max];
int boxpointer;
}; class readybox// 已归约栈 { public:
readybox
{
box[0]="#";
boxpointer=0;
}
void push(char fu)
{
boxpointer++;
box[boxpointer]=fu;
}
char pop
{
char a=box[boxpointer];
boxpointer;
return a;
}
char box[max];
int boxpointer; }; int program(stylebox&style,readybox&ready,char fu,int icount,string ptr,int control)// 返回就是否需要移进信号 { if(control==1) {
//////////////////////////////
char ber[max];
sprintf(ber,"%d",count);
string st=ber;
pp=pp+st+"
";
count++;
////////////////////////////////////
//
pp=pp+"
";
for(int qq=0;qq<=style 、boxpointer;qq++)
{
char bss[max];
sprintf(bss,"%d",style 、box[qq]);
string st=bss;
pp=pp+st;
}
for(qq=0;qq<10style 、boxpointer;qq++)
{
pp=pp+" ";
}
for( qq=0;qq<=ready 、boxpointer;qq++)
{
pp=pp+ready 、box[qq];
}
for(qq=0;qq<10ready 、boxpointer;qq++)
{
pp=pp+" ";
}
for(int dj=icount;dj<ptr 、length;dj++)
{
pp=pp+ptr[dj];
}
pp=pp+"
"; //
////////////////////////////////////////
}
int i=style 、pop;// 如果就是 s 则状态还要入栈 // cout<<" 现在状态"<<i;
int j=checkendfu(fu);
if(j==1)
{
pp=pp+"error!!!";
return 4;//wrong!!!
} // cout<<"
现在符号: "<<fu<<" "<<j<<endl;
int checkstyle=smarttable[i][j] 、actype;// 查表
if(checkstyle==4)
{
pp=pp+"error!!!";
return 4;//wrong!!!
}
if(checkstyle==0||checkstyle==3)
{
style 、push(i);// 如果就是 s 则状态还要入栈
if(checkstyle==0)
{
//cout<<"ACTION["<<i<<","<<fu<<"]=S"<<smarttable[i][j] 、number<<",状 状态 态"<<smarttable[i][j] 、number<<" 入栈"<<endl;
pp=pp+"ACTION[";
char buffer[max];
sprintf(buffer,"%d",i);
string s=buffer;
pp=pp+s;
pp=pp+",";
pp=pp+fu;
pp=pp+"]=S";
char buf[max];
sprintf(buf,"%d",smarttable[i][j] 、number);
s=buf;
pp=pp+s;
pp=pp+", 状态";
pp=pp+s+" 入栈"+hh;
}
if(checkstyle==3)
{
// cout<<i<<","<<endfureal[j]<<")="<<smarttable[i][j] 、 number<<"入栈"<<endl;
char bf[max];
sprintf(bf,"%d",i);
string s=bf;
pp=pp+s;
pp=pp+","+endfureal[j]+")=";
char bfff[max];
sprintf(bfff,"%d",smarttable[i][j] 、number);
s=bfff;
pp=pp+s+" 入栈"+hh;
}
ready 、push(fu);
style 、push(smarttable[i][j] 、number); //
cout<<style 、box[style 、boxpointer]<<endl;
return 1;// 移进
}
if(checkstyle==1)
{
string l=creatword[smarttable[i][j] 、number];
// cout<<"r"<<smarttable[i][j] 、number+1<<": "<<l<<" 归约,GOTO(";
pp=pp+"r";
int dd=smarttable[i][j] 、number+1;
char bfc[max];
sprintf(bfc,"%d",dd);
string ss=bfc;
pp=pp+ss+": "+l+" 归约,GOTO(";
char n;//pop 用得
int x;
// cout<<l 、length<<endl;
char sq=ready 、pop;
for(x=0;x<l 、length4;x++)// 前面 pop 一次了
{
n=style 、pop;
n=ready 、pop; //
cout<<n<<endl;
}
// cout<<l[0]<<endl;
x=program(style,ready,l[0],icount,ptr,0);// 识别非终结符
return 0;// 归约
}
if(checkstyle==2)
{
return 2;// 接受
} } int main {
// TODO: Add extra validation here
string str;
cin>>str; //0=i 1=+ 2=* 3=( 4=) 5=# 6=E 7=T 8=F
smarttable[0][0] 、action(0,5);
smarttable[0][3] 、action(0,4);
smarttable[0][6] 、action(3,1);
smarttable[0][7] 、action(3,2);
smarttable[0][8] 、action(3,3);
smarttable[1][1] 、action(0,6);
smarttable[1][5] 、action(2,0);
smarttable[2][1] 、action(1,1);
smarttable[2][2] 、action(0,7);
smarttable[2][4] 、action(1,1);
smarttable[2][5] 、action(1,1);
smarttable[3][1] 、action(1,3);
smarttable[3][2] 、action(1,3);
smarttable[3][4] 、action(1,3);
smarttable[3][5] 、action(1,3);
smarttable[4][0] 、action(0,5);
smarttable[4][3] 、action(0,4);
smarttable[4][6] 、action(3,8);
smarttable[4][7] 、action(3,2);
smarttable[4][8] 、action(3,3);
smarttable[5][1] 、action(1,5);
smarttable[5][2] 、action(1,5);
smarttable[5][4] 、action(1,5);
smarttable[5][5] 、action(1,5);
smarttable[6][0] 、action(0,5);
smarttable[6][3] 、action(0,4);
smarttable[6][7] 、action(3,9);
smarttable[6][8] 、action(3,3);
smarttable[7][0] 、action(0,5);
smarttable[7][3] 、action(0,4);
smarttable[7][8] 、action(3,10);
smarttable[8][1] 、action(0,6);
smarttable[8][4] 、action(0,11);
smarttable[9][1] 、action(1,0);
smarttable[9][2] 、action(0,7);
smarttable[9][4] 、action(1,0);
smarttable[9][5] 、action(1,0);
smarttable[10][1] 、action(1,2);
smarttable[10][2] 、action(1,2);
smarttable[10][4] 、action(1,2);
smarttable[10][5] 、action(1,2);
smarttable[11][1] 、action(1,4);
smarttable[11][2] 、action(1,4);
smarttable[11][4] 、action(1,4);
smarttable[11][5] 、action(1,4); string enter=str;
int i;
int x;
stylebox st;
readybox ready;
for(i=0;i<enter 、length;)
{
// cout<<"enter:
"<<enter[i]<<"
"<<endl;
x=program(st,ready,enter[i],i,enter,1);
if(x==1)i++;
if(x==2)
{
// cout<<"Acc: 分析成功 功"<<endl;
pp=pp+"Acc: 分析成功"+hh;
break;
}
if(x==4)
break;
// cout<<endl;
// cout<<endl;
// pp=pp+hh;
} cout<<pp; // CDialog::OnOK; } 七、 实验总结
通过本次试验使我不仅对 LR(1)分析法有了更深得了解,而且提高了编程能力,希望在以后得学习中可以解决 LR(1)中确定化得问题。
- 范文大全
- 职场知识
- 精美散文
- 名著
- 讲坛
- 诗歌
- 礼仪知识
-
入党积极分子个人2024思想汇报12篇
入党积极分子个人2024思想汇报12篇 当我开始写这篇心得的时候,我的心里是很激动的。真的,就像在平静如湖的心田里忽然扔进了一块石子
【思想汇报】 日期:2024-02-20
-
对于政治生态考核整改工作方案
本文系作者原创投稿,仅供学习参考,请勿照搬照抄! 关于政治生态考核整改工作的方案 为做好推进风清气正
【经济工作】 日期:2020-06-05
-
大学生学习2024年两会精神心得感悟
大学生学习2024年两会精神心得感悟过去一年,是全面贯彻二十大精神的开局之年,中国共产党带领全国各族人民,付出艰辛努力,换来重大成
【心得体会】 日期:2024-03-07
-
入党积极分子2024年第一季度思想汇报9篇
入党积极分子2024年第一季度思想汇报9篇 伟大、光荣、正确的中国共产党,是中华民族伟大复兴的中流砥柱,是领导我们事业的核心力量。
【思想汇报】 日期:2024-03-13
-
服装店面装修设计图【女装小店面装修效果图设计图】
随着服装行业和照明产业的发展日趋成熟,服装店的照明设计越来越受到人们的广泛关注,即通过光环境设计对消费者产生引导性作用。那么女装小店面要如何装修呢?下面小编...
【党会发言】 日期:2019-05-09
-
[女装批发店面装修图片欣赏] 女装店面装修效果图
店面是服装企业的形象,店面色彩又是人们对服装企业的第一视觉感觉,企业要建立良好的企业文化,提高销售额,增强其竞争力,必需要有一套完备的店面色彩设计密码。下面小编就...
【述职报告】 日期:2019-05-07
-
地藏经诵读仪规(完整版)
地藏经诵读仪规(完整版) 恭请文: 恭请大慈大悲大愿地藏王菩萨、护法诸天菩萨慈悲加持护念弟子***能
【个人简历】 日期:2021-03-31
-
青年学生学习全国人大十四届二次会议心得感想16篇
青年学生学习全国人大十四届二次会议心得感想16篇报告中提到政府在经济调控、消费政策、基础设施和制造业投资、房地产调控以及地方债务
【心得体会】 日期:2024-03-07
-
三八妇女节贺卡图片_三八妇女节送给妈妈的贺卡欣赏
2017年妇女节大家准备送什么礼物给自己的妈妈呢?各种各样的手工制作贺卡供大家选择,小编分享三八妇女节送给妈妈的贺卡,希望大家喜欢! 三八妇女节送给妈妈的贺卡展示...
【党会发言】 日期:2020-03-15
-
基尔霍夫定律验证实验报告
基尔霍夫定律的验证的实验报告本文关键词:基尔,定律,霍夫,验证,实验基尔霍夫定律的验证的实验报告本文
【思想宣传】 日期:2021-03-08
-
执行信息公开网
执行信息公开网 执行信息公开网 执行信息公开网: zhi*ing (点击下图可直接进行访问) 全国
【职场知识】 日期:2020-07-03
-
【影子是怎么形成的】影子是怎样形成的?
一种光学现象,影子不是一个实体,只是一个投影。那么影子是怎么形成的?小编在此整理了影子形成的原因,供大家参阅,希望大家在阅读过程中有所收获! 影子形成的原因 光...
【职场知识】 日期:2020-03-12
-
“以学生为中心”的教学原则
以学生为中心的教学原则教师在开展以学生为中心的教学实践中,必须谨记学习目标不再是知识的获得,能力要比知识更重要。以下是蒲公英阅读网
【职场知识】 日期:2023-01-05
-
服装店店面装修图 [时尚服装店面装修图]
服装店是为顾客设计的,在设计要求上,会存在着不少差异。在服装店装修中还应重视绿色设计的问题。下面小编就为大家解开时尚服装店面装修图,希望能帮到你。 时尚服装店面装...
【职场知识】 日期:2019-05-16
-
致橡树(中英文)
3 【原诗】 【JohannaYueh修改版】 致橡树TotheOakTree 作者:舒婷ByShu
【职场知识】 日期:2020-11-17
-
心理健康黑板报_心理健康黑板报图片
虽然工作上难免压力,但是只要正视压力,一切就不会太辛苦。下面就随小编看看心理健康黑板报内容,希望喜欢哦。 心理健康黑板报图片欣赏 心理健康黑板报图片1 心理健...
【职场知识】 日期:2020-02-26
-
有机磷酸酯类中毒及其解救(实验报告范文)
有机磷酸酯类中毒及其解救XXX、XXX一、实验目的1 观察有机磷酸酯类农药敌百虫中毒时的症状。 2
【职场知识】 日期:2020-08-30
-
店面装修风格效果图_女装店面装修欧美风效果图
近年来,国内女装品牌越来越多,并开始进入了同质化竞争状态。很多女装企业选择了通过卖场设计来体现品牌风格。下面小编就为大家解开女装店面装修欧美风展示,希望能帮到你。 ...
【职场知识】 日期:2019-05-07
-
【语文连接词的用法】初中语文常见的连接词
连词是用来连接词与词、词组与词组或句子与句子、表示某种逻辑关系的虚词。语文连接词的用法是什么有哪些呢?下面是小编整理的语文连接词的用法,欢迎阅读 语文连接词作主要...
【职场知识】 日期:2020-03-05
-
2017流行适合胖新娘的发型 新娘发型图片2017款
结婚时新娘肯定要做发型的,那么什么样的发型会让脸大的新娘显得小脸美丽呢?以下是小编为你精心整理的2017流行适合胖新娘的发型,希望你喜欢。 2017流行适合胖新娘的发型 ...
【职场知识】 日期:2020-03-10
-
十三五规划(全文)
十三五规划建议发布(全文) 2015年11月03日16:06来源:新华网新华社北京11月3日电中共中
【古典文学】 日期:2020-09-12
-
唐代诗人李昂个人信息
唐代诗人李昂个人信息 导读:我根据大家的需要整理了一份关于《唐代诗人李昂个人信息》的内容,具体内容:
【古典文学】 日期:2020-11-07
-
[关于中秋的朗诵诗词] 关于爱国的朗诵诗词
中秋,热闹的街头树起了灯彩,舞起了火龙。你知道多少关于中秋的朗诵诗词?下面小编为你整理了几篇关于中秋的朗诵诗词,希望对你有帮助。 关于中秋的朗诵诗词一 中秋佳节...
【古典文学】 日期:2019-06-06
-
丽江古城旅游攻略_详细丽江古城旅游攻略线路
丽江古城是一座没有城墙的古城,她依山傍水,风景秀丽。古城内光滑的石板路、手工建造的土木结构房屋、无处不在的小桥流水,无一不在向世人展示着她的恬静清幽。丽江自助游攻...
【古典文学】 日期:2020-03-12
-
2021公安专业知识考试练习题(附答案)
2021公安专业知识考试练习题(附答案) 1 甲地公安机关接到群众举报,在当天举行的大型娱乐活动中,
【古典文学】 日期:2021-01-29
-
猪油膏的用法_猪油膏哪个牌子好
猪油膏是BENEFIT的丝柔打底膏,因为形态有点像凝固的猪油,所以得此称呼。下面小编给大家介绍猪油膏的使用方法。 猪油膏的使用方法 1 在使用猪油膏前,一定要有一个干...
【古典文学】 日期:2020-03-14
-
儿童文字睡前故事大全 睡前长篇童话故事大全
睡前故事可以营造温馨的心理环境,帮助孩子把情绪调节到准备入睡的状态。我们应该怎样为孩子选择睡前故事呢?下面是小编为您整理的儿童文字睡前故事大全,希望对你有所帮助! ...
【古典文学】 日期:2019-05-17
-
大气唯美黑板报【国庆节大气黑板报】
日本在投降的那一天,再也没有昔日的嚣张,我们中国的屈辱得到洗刷。下面就随小编看看国庆节大气黑板报内容,希望喜欢哦。 国庆节大气黑板报图片欣赏 国庆节大气黑板报...
【古典文学】 日期:2019-05-05
-
恒星英语听力网_普特英语听力网
恒星英语听力网的英语听力材料。下面是小编给大家整理的恒星英语听力网的相关知识,供大家参阅! 恒星英语听力网听力篇1 LessonThirty-Six SectionOne: A Makinga...
【古典文学】 日期:2019-05-30
-
爱的华尔兹的歌词_爱的华尔兹在线试听
郑爽唱的爱的华尔兹不知道你们是否都还有影响?让我们一起去看看吧!下面是!让小编我来帮你们查找关于爱的华尔兹的歌词的信息吧,希望能对你有用! 爱的华尔兹的歌词 郑爽-...
【古典文学】 日期:2020-03-19
-
【世界上最大的半岛】阿拉伯半岛
你知道世界上最大的半岛是什么吗?下面由小编来介绍一下。 阿拉伯半岛的简介 阿拉伯半岛(阿拉伯文:)位于亚洲,是世界上最大的半岛。沙特阿拉伯、也门、阿曼、阿拉伯联合...
【中国文学】 日期:2019-05-24
-
2021年超星尔雅学习通《辩论与修养》章节测试试题(共183题附答案)
2021年超星尔雅学习通《辩论与修养》章节测试试题(共183题附答案)1、辩论的目的不是单纯获得某种
【中国文学】 日期:2021-05-12
-
古代人物漫画女生唯美图片欣赏 漫画人物图片女孩唯美
中国漫画始于清末民初,而平面设计虽然其名称是在改革开放以后确立的,但设计活动却自古就有,二者的相互影响是本文的主要讨论范围。小编整理了唯美古代女生人物漫画,欢迎阅读!...
【中国文学】 日期:2020-03-19
-
广州好吃的西餐厅|广州环境好的西餐厅
一份西餐,在你的心中是一种什么样的味道?多年来,广州大大小小的西餐厅不计其数,但是要找上性价比高且又品位有逼格点西餐厅有哪些,就来看看小编推送给大家的西餐厅吧。 ...
【中国文学】 日期:2019-05-10
-
北京不贵且好吃的餐厅 北京好吃不贵的餐厅
朋友小聚,逛街之余,吃顿便饭,不用总去那么高大上的地方,挑个人气高还平价的餐厅,一个月去个几回也根本不用担心月末要吃土!下面小编给大家介绍北京几家好吃不贵的餐厅,来...
【中国文学】 日期:2020-02-28
-
镇2021年开展创建“土地执法模范村”活动方案例文稿
镇镇12021年开展创建“土地执法模范村”活动方案范文稿 为了巩固和扩大我镇
【中国文学】 日期:2021-05-10
-
危险化学品信息表-柴油
危险化学品信息表-柴油本文关键词:柴油,危险化学品,信息危险化学品信息表-柴油本文简介:危险化学品信
【中国文学】 日期:2021-03-17
-
爱情的英语作文|关于爱情的英语作文
爱情的英语作文,书写了世界上伟大的爱情。下面是小编给大家整理的爱情的英语作文的相关知识,供大家参阅! 爱情的英语作文篇1 Loveisthemostbeautifulthingintheworld,i...
【中国文学】 日期:2020-03-10
-
杨绛经典语录摘抄_杨绛先生经典语录摘抄
杨绛先生的身份很多,本人是西班牙语专业的,就从自己的角度,说一个杨绛先生的经典语录吧。以下是小编为你精心整理的杨绛先生经典语录摘抄,希望你喜欢。 杨绛先生经典语录摘...
【中国文学】 日期:2019-05-05
-
什么是品质管理_品质管理规定
为确保及提高产品品质符合管理及市场需要,完善产品品质管理制度,制定了品质相关管理规定,下面小编给大家介绍关于品质管理规定的相关资料,希望对您有所帮助。 品质管理...
【中国文学】 日期:2020-03-03
-
改革开放大事记简表(改革开放新时期1978-2012年)
改革开放大事记简表 (1978-2012年) 时间1978年12月18日至22日地点北京事件党的十一
【外国名著】 日期:2021-06-17
-
时尚餐厅店面装修图片_餐厅店面装修效果图
餐饮业是通过即时加工制作、商业销售和服务性劳动于一体,向消费者专门提供各种酒水、食品,消费场所和设施的食品生产经营行业。下面小编就为大家解开时尚餐厅店面装修图片,...
【外国名著】 日期:2019-05-16
-
小型服装店装修效果图【小服装店店面装修效果图】
当前在服装店室内设计中,存在着几种不良的倾向,有碍于服装店装修体现的顾客满意气氛。下面小编就为大家解开小服装店店面装修效果图,希望能帮到你。 小服装店店面装修效果...
【外国名著】 日期:2019-05-28
-
手机大尺度直播平台 [尺度最大的手机直播有哪些]
现在哪个手机直播平台尺度大?尺度大的手机直播App有哪些?小编为您介绍一下尺度最大的手机直播。 尺度最大的手机直播有哪些? 第一坊 第一坊视频平台是一款优质美女直...
【外国名著】 日期:2020-03-07
-
牛百叶的做法大全家常【牛百叶的做法大全家常怎么做好吃】
牛百叶最经典的做法就是涮火锅,而牛百叶还有哪些做法呢?下面是小编精心为你们整理的关于牛百叶的做法大全家常的相关内容,希望你们会喜欢! 红油白百叶的做法 原料:白...
【外国名著】 日期:2020-02-26
-
戴维南定理实验报告
实验一:戴维南定理学号:1528406027 姓名:李昕怡 成绩: 一、 实验目的 1.深刻理解和掌
【外国名著】 日期:2021-05-27
-
成都生日蛋糕排行榜【成都生日蛋糕哪家最好吃】
又到了一年情人节!这次小编为大家精心挑选出成都当季最好吃的生日蛋糕店,来看看吧。 成都生日蛋糕哪家最好吃1、宫廷糕点 地址:成华区建设路47号 吃货说:觉得他家...
【外国名著】 日期:2019-06-04
-
《怦然心动(2010)》电影完整中英文对照剧本
我最大的愿望就是朱莉·贝克能离我远点AllIeverwantedwasforJuliB
【外国名著】 日期:2020-07-27
-
[10.1旅游去哪里好玩] 旅游去哪里好玩
十月一到,秋意已在一个我们不经意的黎明走来,习习凉风,却是最适合出门游行。小编为您整理了10 1旅游去哪里好玩,秋天,我们一起出发吧。 1、云南建水古城 建水古城...
【外国名著】 日期:2020-03-01
-
家用玉米脱粒机设计
家用玉米脱粒机设计 摘 要 20世纪70年代初,我国发展的纺织机械对纺织机械原理的影响,尤其是在大中
【外国名著】 日期:2020-12-24
-
梧桐花的花语|梧桐花的功效与作用
梧桐花为梧桐科植物梧桐的花,植物形态详梧桐子条。今天小编为你整理了梧桐花的花语,欢迎阅读。 梧桐花的花语是:情窦初开 在春季里晚开的花朵,有着恬淡的气息。 ...
【寓言童话】 日期:2020-03-03
-
北京最好吃的自助餐厅 北京高档自助餐排名
自助餐简直就是拯救大胃王的最佳饮食!没有之一!世界上没有什么事情是吃一顿自助餐解决不了的,如果有,那就吃两顿!下面小编给大家推荐北京几家好吃的自助餐。 北京最好吃的...
【寓言童话】 日期:2020-02-25
-
油管、套管规格尺寸对照表
API油管规格及尺寸 公称尺寸(in) 不加厚外径(mm) 不加厚内径(mm) 加厚外径(mm) 加
【寓言童话】 日期:2020-08-31
-
运动心理学
运动心理学名词解释: 1、运动表象:通常是指在人的头脑中重现出来的动作表象,它反映动作在一定的时间、
【寓言童话】 日期:2021-06-08
-
100元钱折纸大全 图解 100元人民币折纸
折纸也是一门艺术,大家知道怎么用100元人民币折纸吗?今天,小编为大家带来了100元人民币折纸,希望大家喜欢! 100元人民币折纸方法 步骤1 步骤2 步骤3 步骤4 ...
【寓言童话】 日期:2020-03-12
-
毕业论文引言格式 论文引言格式范例
引言(前言、导言、绪言、序言)是正文的引子,相当于演说中的开场白。下面是小编整理了毕业论文引言格式,有兴趣的亲可以来阅读一下! 毕业论文引言格式 引言:引言又称前...
【寓言童话】 日期:2020-03-01
-
调剂给导师邮件范文2篇
调剂给导师的邮件模板22篇 篇一尊敬的XX老师:您好!我是一名想调剂到贵校XXX方向的一名学生,冒昧
【寓言童话】 日期:2020-05-29
-
起重吊装知识
起重吊装基础知识一、常用的索具和吊具(一)麻绳1 麻绳的性能和种类(1)麻绳的特点与用途麻绳具有质地
【寓言童话】 日期:2020-09-30
-
西部计划笔试题库(99题含答案)
西部计划笔试题库(99题含答案) 1 第十三届全国人大三次会议表决通过了《中华人民共和国民法典》,自
【寓言童话】 日期:2021-06-16
-
【高中生物实验归纳】高中生物实验总结大全
生物学是一门以观察和实验为基础的自然科学,学生可以把高中所学习到的实验知识点进行归纳梳理,下面是小编给大家带来的高中生物实验归纳,希望对你有帮助。 高中生物实验...
【寓言童话】 日期:2020-03-05
-
学生高考动员演讲稿
学生高考动员演讲稿3篇高考动员演讲稿11 老师们、同学们: 大家下午好!漫漫高考长征路已经进入尾声了
【百家讲坛】 日期:2021-09-22
-
企业安全演讲稿2021
最新企业安全的演讲稿5篇 演讲稿是作为在特定的情境中供口语表达使用的文稿。在充满活力,日益开放的今天
【百家讲坛】 日期:2021-09-22
-
XX镇扶贫项目实施专项整治工作总结_1
XX镇扶贫项目实施专项整治工作总结 为深入贯彻精准扶贫精准脱贫基本方略,认真落实党中央、国务院,省委
【百家讲坛】 日期:2021-09-22
-
对乡镇领导班子干部成员批评意见例文
对乡镇领导班子干部成员的批评看法范文 一、对党委书记XXX同志的批评看法〔3条〕 1、与干部交流偏少
【百家讲坛】 日期:2021-09-22
-
群英乡扶贫资金项目芬坡村祖埇村生产道路硬化工程绩效自评报告
群英乡扶贫资金项目((芬坡村祖埇村生产道路硬化工程))绩效自评报告 一、基本情况(一)群英乡扶贫资金
【百家讲坛】 日期:2021-09-22
-
党委书记警示教育大会上讲话2021汇编
党委书记在警示教育大会上的讲话55篇汇编 党委书记在警示教育大会上的讲话(一) 同志们: 根据省州委
【百家讲坛】 日期:2021-09-22
-
对于2021年召开巡视整改专题民主生活会对照检查材料
关于12021年召开巡视整改专题民主生活会对照检查材料 按照中央巡视组要求和省、市、区委统一部署,区
【百家讲坛】 日期:2021-08-14
-
消防安全知识培训试题.doc
消防安全知识培训试题姓名: 部门班组: 成绩: 一:填空题,每空4分,共44分。 1、灭火剂是通过隔
【百家讲坛】 日期:2021-08-14
-
涉疫重点人员“五包一”居家隔离医学观察工作流程
涉疫重点人员“五包一”居家隔离医学观察工作流程 目前,全球疫情仍处于大流行状
【百家讲坛】 日期:2021-08-14
-
疫情防控致全体师生员工及家长一封信
疫情防控致全体师生员工及家长的一封信 各位师生员工及全体家长朋友: 暑假已至,近期我省部分地方发现确
【百家讲坛】 日期:2021-08-14