编译原理实验2——自动机的确定化和最小化

2024-06-05 11:08

本文主要是介绍编译原理实验2——自动机的确定化和最小化,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

(前言:这个代码的产生真的是非常非常曲折。。。。
因为退役之后没事儿干,打算好好折腾ubuntu玩玩,结果装系统的时候把win装崩了,作业还没备份直接全没了。。
我重写的时候真的是眼里全是泪水。。。
后来实验报告写好了之后,又萌萌哒地没有备份,又留在机房一次= =
后来又是重写啊啊啊啊啊啊啊啊啊啊啊!)
使用说明:
调用NFA中的init函数可以对数组进行初始化。
调用NFA中的read函数可以将数据读入进来。
调用NFA中的check函数可以判断该结构为DFAor NFA。
调用NFA中的ChangeToDFA函数可以将该自动机对应的DFA输出出来。
调用DFA中的output可以输出对应的DFA
调用DFA中的 GetMinDFA可以输出对应的最小化的自动机。数据格式:
首先两个整数n,m,代表有n个状态m条转移。
接下来m行数,每一行有两个整数u,v和一个字符c,代表u可以通过c转移到v去。(用~代表空符号)
接下来一个数s代表起始状态。
接下来一个数Tcnt代表接收状态的个数。
接下来Tcnt个数代表接收状态的具体标号。
(状态编号为0--n- 1)样例:
3 7
0 2 0
0 0 1
1 0 0
1 1 0
2 0 0
2 1 1
2 2 0
0
1
2DFA中output的输出格式:
如果DFA中的状态有x个,转移字符有c个,那么接下来有x行
第i行为i:,接下来c个字符分别代表第i个状态接收第j个字符后转移到的状态,-1为无对应状态


代码如下:

#include<iostream>
#include<queue>
#include<iomanip>
#include<map>
#include<vector>
#include<cstring>
#include<algorithm>
using namespace std;
const int N = 1005;
const int M = 1005;
const int CSIZE = 26;
struct DFA{/*{{{*/struct Node{int x,y,id;Node(){}Node(int x,int y,int id):x(x),y(y),id(id){}bool operator < (const Node &a)const{if(x != a.x) return x < a.x;return y < a.y;}bool operator == (const Node &a)const{return x == a.x && y == a.y;}};int ch[N][CSIZE];int cnt,C;bool accept[N];void init(){cnt = 0;memset(ch,-1,sizeof(ch));memset(accept,0,sizeof(accept));}

这篇关于编译原理实验2——自动机的确定化和最小化的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1032883

相关文章

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

MySQL中的MVCC底层原理解读

《MySQL中的MVCC底层原理解读》本文详细介绍了MySQL中的多版本并发控制(MVCC)机制,包括版本链、ReadView以及在不同事务隔离级别下MVCC的工作原理,通过一个具体的示例演示了在可重... 目录简介ReadView版本链演示过程总结简介MVCC(Multi-Version Concurr

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

Redis主从/哨兵机制原理分析

《Redis主从/哨兵机制原理分析》本文介绍了Redis的主从复制和哨兵机制,主从复制实现了数据的热备份和负载均衡,而哨兵机制可以监控Redis集群,实现自动故障转移,哨兵机制通过监控、下线、选举和故... 目录一、主从复制1.1 什么是主从复制1.2 主从复制的作用1.3 主从复制原理1.3.1 全量复制

Redis主从复制的原理分析

《Redis主从复制的原理分析》Redis主从复制通过将数据镜像到多个从节点,实现高可用性和扩展性,主从复制包括初次全量同步和增量同步两个阶段,为优化复制性能,可以采用AOF持久化、调整复制超时时间、... 目录Redis主从复制的原理主从复制概述配置主从复制数据同步过程复制一致性与延迟故障转移机制监控与维

SpringCloud配置动态更新原理解析

《SpringCloud配置动态更新原理解析》在微服务架构的浩瀚星海中,服务配置的动态更新如同魔法一般,能够让应用在不重启的情况下,实时响应配置的变更,SpringCloud作为微服务架构中的佼佼者,... 目录一、SpringBoot、Cloud配置的读取二、SpringCloud配置动态刷新三、更新@R

Redis主从复制实现原理分析

《Redis主从复制实现原理分析》Redis主从复制通过Sync和CommandPropagate阶段实现数据同步,2.8版本后引入Psync指令,根据复制偏移量进行全量或部分同步,优化了数据传输效率... 目录Redis主DodMIK从复制实现原理实现原理Psync: 2.8版本后总结Redis主从复制实

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

hdu4407(容斥原理)

题意:给一串数字1,2,......n,两个操作:1、修改第k个数字,2、查询区间[l,r]中与n互质的数之和。 解题思路:咱一看,像线段树,但是如果用线段树做,那么每个区间一定要记录所有的素因子,这样会超内存。然后我就做不来了。后来看了题解,原来是用容斥原理来做的。还记得这道题目吗?求区间[1,r]中与p互质的数的个数,如果不会的话就先去做那题吧。现在这题是求区间[l,r]中与n互质的数的和

hdu 3065 AC自动机 匹配串编号以及出现次数

题意: 仍旧是天朝语题。 Input 第一行,一个整数N(1<=N<=1000),表示病毒特征码的个数。 接下来N行,每行表示一个病毒特征码,特征码字符串长度在1—50之间,并且只包含“英文大写字符”。任意两个病毒特征码,不会完全相同。 在这之后一行,表示“万恶之源”网站源码,源码字符串长度在2000000之内。字符串中字符都是ASCII码可见字符(不包括回车)。