设计思想(1)程序主体结构部分:说明部分%%规则部分%%辅助程序部分(2)主体结构的说明在这里说明部分告诉我们使用的LETTER,DIGIT,IDENT(标识符,通常定义为字母开头的字母数字串)和STR(字符串常量,通常定义为双引号括起来的一串字符)是什么意思.这部分也可以包含一些初始化代码.例如用#include来使用标准的头文件和前向说明(forward,references).这些代码应该再标记"%{"和"%}"之间;规则部分>可以包括任何你想用来分析的代码;我们这里包括了忽略所有注释中字符的功能,传送ID名称和字符串常量内容到主调函数和main函数的功能.(3)实现原理程序中先判断这个句语句中每个单元为关键字、常数、运算符、界符,对与不同的单词符号给出不同编码方式的编码,用以区分之。
PL/0语言的EBNF表示::==;::=={|};::=+|-::=*|/::==|#|=::=a|b|…|X|Y|Z::=0|1|2|…|8|9三:设计过程1.关键字:void,main,if,then,break,int,Char,float,include,for,while,printfscanf并为小写。
2."+”;”-”;”*”;”/”;”:=“;”:”;”=“;”“;”=“;”(“;”)”;”;”;”#”为运算符。
3.其他标记如字符串,表示以字母开头的标识符。
4.空格符跳过。
5.各符号对应种别码关键字分别对应1-13运算符分别对应401-418,501-513。
字符串对应100常量对应200结束符#四:举例说明目标:实现对常量的判别代码:digit[0-9]letter[A-Za-z]other_char[!-@\[-~]id({letter}|[_])({letter}|{digit}|[_])*string{({letter}|{digit}|{other_char})+}int_num{digit}+%%[|\t|\n]+"auto"|"double"|"int"|"struct"|"break"|"else"|"long"|"switch"|"case"|"enum"|"register"|"typedef"|"char"|"extern"|"return"|"union"|"const"|"float"|"short"|"unsigned"|"continue"|"for"|"signed"|"void"|"default"|"goto"|"sizeof"|"do"|"if"|"static"|"while"|"main"{Upper(yytext,yyleng);printf("%s,NULL\n",yytext);}\"([!-~])*\"{printf("CONST_string,%s\n",yytext);}-?{int_num}[.]{int_num}?([E][+|-]?{int_num})?{printf("CONST_real,%s\n",yytext);}"0x"?{int_num}{printf("CONST_int,%s\n",yytext);}","|";"|"("|")"|"{"|"}"|"["|"]"|"->"|"."|"!"|"~"|"++"|"--"|"*"|"&"|"sizeof"|"/"|"%"|"+"|"-"|">"|"="|">="|"<<="|"&="|"^="|"|="|"="{printf("%s,NULL\n",yytext);}{id}{printf("ID,%s\n",yytext);}{digit}({letter})+{printf("error1:%s\n",yytext);}%%#includeUpper(char*s,intl){inti;for(i=0;i<l;i++){s[i]=toupper(s[i])
2021/11/7 5:50:07 105KB 词法分析器制作
1
包含windows下和linux下的udp客户端/服务端程序。
windows下的程序用vc6控制台程序编写,linux下的程序用gcc编译即可。
除了同一操作系统下的udp通信外,还能进行windows下与linux下的客户端与服务端通信。
出现中文乱码的话,那一定是运行此程序的窗口的编码格式不一致,只需改为一致就可以了。
如果要将dos窗口的编码方式改为UTF8,可参考:http://blog.csdn.net/joeblackzqq/article/details/7010322
2019/7/2 12:56:05 72KB udp socket通信
1
易言语写出文件、写出字节集编码方式
1
SystemView仿真软件可以实现多层次的通信系统仿真。
脉冲编码调制(PCM)是现代语音通信中数字化的重要编码方式。
利用SystemView实现脉冲编码调制(PCM)仿真,可以为硬件电路实现提供理论依据。
通过仿真展现了PCM编码实现的设计思路及具体过程,并加以进行分析。
2017/4/12 3:58:08 477KB 课程设计
1
1.基于MFC通过多线程实现多个客户端同时连接服务器。
2.服务端通过维护一张转发表来实现对客户端信息的转发,比如客户端A向客户端B发送消息,服务器接收到客户端A发过来消息内容和客户端B信息之后,通过转发表查找到客户端B的Socket,将内容转发给客户端B,实现客户端之间的通信。
3.运转程序时先运转服务端,再运转客户端。
4.本程序没有转换编码方式,所以不能传输中文,各位可以自行实现。
2015/3/24 21:37:22 55.88MB C++ MFC Socket
1
遗传算法首先会采用一种编码方式将解空间映射到一个编码空间,每一个编码对应问题的一个解,称之为个体或者染色体,然后再随机生成确定起始的一群个体,称之为种群。
在后续迭代的过程中,按照适者生存不适者淘汰的原理,根据适应度大小选择个体,并且借助各种不同的遗传算子对个体进行交叉和变异,生成一个代表新的解集的种群,这个种群会比前一代愈加适应环境,如此一直进化下去直到到达优化准则。
这个时候的末代个体,经过解码,得到的解可近似的作为问题的最优解。
2022/9/3 0:55:55 1KB 遗传算法
1
C#写的二维码编码类和二维码解码类,不调用任何控件,方便翻译成任何语言,可在任意平台上运行。
内有说明文档,说明怎样设置和调用,使用非常的方便,编码一个类,解码一个类,不像网上搜索的那些各种复杂不好用,是我把网上搜索的冗长的代码精简提炼出来的。
以下为使用说明:编码:命名空间:namespaceewmbm二维码类名:publicclassewmbm二维码编码可设置变量 1:ewmbm二维码编码.blx类型//编码类型,数字、字母或者中文(默认中文) 2:ewmbm二维码编码.bbb版本//数据容量(默认版本7) 3:ewmbm二维码编码.bjcdj纠错等级//低、中、高、完满(默认中) 4:ewmbm二维码编码.bfdbs放大倍数//每个数据点宽几个像素(默认4) 5:ewmbm二维码编码.bmfs编码方式//(默认UTF8)准备工作: 将【二维码\Resources】中的所有dat文件,加入资源文件 或者: 将代码中三处读取资源文件的地方改成读取文件也可以, 搜索【btemp=(sbyte[])二维码.Properties.Resources.ResourceManager.GetObject(fileName);】即可找到三处读取资源文件的地方使用函数: usingewmbm二维码; Bitmapbtemp=ewmbm二维码.ewmbm二维码编码.drawqr画二维码(string要编码的文字);//***************************************************解码:命名空间间:namespaceewmjm二维码类名:publicclassewmjm二维码解码可设置变量 1:ewmjm二维码解码.bmfs编码方式//(默认UTF8)使用函数: usingewmjm二维码; ewmjm二维码解码decoder=newewmjm二维码解码(); stringttemp=decoder.jm解码(Bitmap要解码的图片);
2016/4/16 3:30:07 1.61MB C# qrcode 二维码 源码
1
浅紧缩编码方式描述文档
2018/11/10 23:25:45 1.41MB 浅压缩
1
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡