导航:首页 > 源码编译 > 编译原理课程设计布尔表达式

编译原理课程设计布尔表达式

发布时间:2022-06-18 05:15:58

1. 编译原理课程设计-词法分析器设计(C语言)

#include"stdio.h"/*定义I/O库所用的某些宏和变量*/

#include"string.h"/*定义字符串库函数*/

#include"conio.h"/*提供有关屏幕窗口操作函数*/

#include"ctype.h"/*分类函数*/

charprog[80]={''},

token[8];/*存放构成单词符号的字符串*/

charch;

intsyn,/*存放单词字符的种别码*/

n,

sum,/*存放整数型单词*/

m,p;/*p是缓冲区prog的指针,m是token的指针*/

char*rwtab[6]={"begin","if","then","while","do","end"};

voidscaner(){

m=0;

sum=0;

for(n=0;n<8;n++)

token[n]='';

ch=prog[p++];

while(ch=='')

ch=prog[p++];

if(isalpha(ch))/*ch为字母字符*/{

while(isalpha(ch)||isdigit(ch))/*ch为字母字符或者数字字符*/{

token[m++]=ch;

ch=prog[p++];}

token[m++]='';

ch=prog[p--];

syn=10;

for(n=0;n<6;n++)

if(strcmp(token,rwtab[n])==0)/*字符串的比较*/{

syn=n+1;

break;}}

else

if(isdigit(ch))/*ch是数字字符*/{

while(isdigit(ch))/*ch是数字字符*/{

sum=sum*10+ch-'0';

ch=prog[p++];}

ch=prog[p--];

syn=11;}

else

switch(ch){

case'<':m=0;token[m++]=ch;ch=prog[p++];

if(ch=='>'){

syn=21;

token[m++]=ch;}

elseif(ch=='='){

syn=22;

token[m++]=ch;}

else{

syn=20;

ch=prog[p--];}

break;

case'>':m=0;token[m++]=ch;ch=prog[p++];

if(ch=='='){

syn=24;

token[m++]=ch;}

else{

syn=23;

ch=prog[p--];}

break;

case':':m=0;token[m++]=ch;ch=prog[p++];

if(ch=='='){

syn=18;

token[m++]=ch;}

else{

syn=17;

ch=prog[p--];}

break;

case'+':syn=13;token[0]=ch;break;

case'-':syn=14;token[0]=ch;break;

case'*':syn=15;token[0]=ch;break;

case'/':syn=16;token[0]=ch;break;

case'=':syn=25;token[0]=ch;break;

case';':syn=26;token[0]=ch;break;

case'(':syn=27;token[0]=ch;break;

case')':syn=28;token[0]=ch;break;

case'#':syn=0;token[0]=ch;break;

default:syn=-1;}}

main()

{

printf(" Thesignificanceofthefigures: "

"1.figures1to6saidKeyword "

"2. "

"3.figures13to28saidOperators ");

p=0;

printf(" pleaseinputstring: ");

do{

ch=getchar();

prog[p++]=ch;

}while(ch!='#');

p=0;

do{

scaner();

switch(syn){

case11:printf("(%d,%d) ",syn,sum);break;

case-1:printf(" ERROR; ");break;

default:printf("(%d,%s) ",syn,token);

}

}while(syn!=0);

getch();

}

程序测试结果

对源程序beginx:=9:ifx>9thenx:=2*x+1/3;end#的源文件,经过词法分析后输出如下图5-1所示:

具体的你在修改修改吧

2. 编译原理布尔表达式和LR(1)求助

回填技术是指控制语句中布尔表达式翻译成四元式序列时,有的转移地址不能在产生这些四元

3. 编译原理布尔表达式和LR求助

D是正确的LL的第一个L表示from Left to right,第二个L表示Left most推导LR的第一个L和LL的第一个L含义相同,第二个R表示Right most推导

4. 编译原理 while 语句文法

while(条件)
{
.......;//语句
X++或者X--;//做自增或自减运算来达到循环的过程
}
while后面跟一堆小括号,里面的条件判断,类似IF语句,当条件满足时做以下语句的循环,条件不满足后直接跳出循环;
例题:
int i=0;//初始化i=0
while(i<5)//i=0满足判断的条件,进入循环语句
{
i++;//做自增运算,当i+到5时跳出循环,因为i不小于5了
}
printf("%d",i);//此时i的值为5

5. 编译原理这门课程第六章中间代码生成的知识点有哪些

编译原理这门课第六章中间代码生成的知识点包含章节导引,第一节中间语言,第二节声明语句,第三节赋值语句,第四节布尔表达式和控制流语句,课后练习,。

6. 有个编译原理的问题麻烦大家帮忙,多谢多谢~~

B -- T
T and F
(B) and F
(B or T) and F

(T or T) and F

(F or T) and F
(true or T) and F
(true or F) and F

(true or false) and F

(true or false) and not F
(true or false) and not false

7. 用C++实现布尔表达式的真值问题

#include <stdio.h>

#include <string.h>


bool eval(const char*s){ if(!s) return 0;

if(*s==0 || *s==')') return 0;


if(*s=='(') return eval(s+1);


const char*p=s;

char c=*p++; if(c!='T' && c!='F') printf("Invalid expression. "); return 0;

bool v=(c=='T')?1:0;


if(*p=='!') v!=eval(p+1);

else if(*p=='|') v|=eval(p+1);

else if(*p=='&')v&=eval(p+1);

else if(*p!=0 && *p!=')')printf("Invalid expression... ");


return v;

}


int main(){

char*s="(T|T)&F&(F|T)";


printf("eval( %s )=%c Press Enter to quit... ", s, (eval(s)==0)?'F':'T');

getchar();

return 0;

}


8. 跪求!我们的作业。 题目:将布尔表达式转换成四元式的程序实现

我自到

9. 急急急,编译原理

using namespace std;

struct BiNode
{
char data;
BiNode *lchild, *rchild;
};
typedef BiNode *BiTree;

int CreateBiTree(BiTree &T, const char *s1, const char *s2, int len)
{
if (len<=0)
{
T = NULL;
return 1;
}
else
{
T = new BiNode;
T->data = *s1;
int i;
for ( i=0; i<len; i++) if (s2[i]==*s1) break;
CreateBiTree(T->lchild, s1+1, s2, i);
CreateBiTree(T->rchild, s1+i+1, s2+i+1, len-(i+1));
}
return 1;
}

int DestroyBiTree(BiTree &T)
{
if (T==NULL) return 1;
DestroyBiTree(T->lchild);
DestroyBiTree(T->rchild);
delete T;
T = NULL;
return 1;
}

int ATraverse(BiTree &T)
{
if (T==NULL) return 1;
ATraverse(T->lchild);
ATraverse(T->rchild);
cout<<T->data;
return 1;
}

main()
{
char a[2000],b[2000];
while(cin>>a>>b)
{
BiTree T;
int count=0;
int n;
for(n=0;a[n]!='\0';n++);
CreateBiTree(T,a,b,n);
ATraverse(T);
cout<<" ";

cout<<endl;
DestroyBiTree(T);

10. 一个编译原理的课程设计,急急急

回答:alkaid_pku
学长
4月14日 06:31 1. 预处理
2. 编译
3. 汇编
4. 查找库函数
5. 连接

阅读全文

与编译原理课程设计布尔表达式相关的资料

热点内容
解压汽车绿本可以找代理人吗 浏览:64
我的世界命令方块在哪 浏览:315
linuxzone 浏览:746
androidapi版本号 浏览:784
小猪佩奇配音解压吃东西 浏览:284
程序员怎么申请公司年会 浏览:870
圈店app的预约头条功能怎么样 浏览:34
云服务器设置ad域 浏览:316
我的世界无尽贪婪奇点压缩器 浏览:394
源码资源免费分享网 浏览:686
批量qq号有效验证源码 浏览:512
本科程序员五年工资 浏览:902
创维电视柜怎么安装app 浏览:853
可爱的程序员陆漓剧照 浏览:851
怎样把截屏压缩成300kb 浏览:226
dart文件加密 浏览:40
java对接摄像头源码 浏览:887
安卓项目开发实例附源码 浏览:730
程序员苹果全家桶 浏览:198
远程命令阻塞 浏览:731