基于DFA的C程序注释删除

本文介绍了如何利用确定有限自动机(DFA)来删除C程序中的注释,包括行内注释、块注释以及字符串内的注释,并提到了处理换行符和空行的特殊情况。给出了状态转换矩阵和C语言代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

有时候一个程序中如果注释太多,也会带来很多的不方便,于是便产生了删除注释的需要,删除注释有很多种方法,不过最近实现的用确定有限自动机(DFA)实现起来感觉也是比较方便的。

经过分析需要删除的注释大概有一下4中情况:

1、int a ; //这里是注释 ;

2、int a ; /*这里

          是注释

            是的*/    ;

3、int a ; /*这里是注释*/ ;

4、对于字符串中的注释符不做处理如:

     printf("adfadsf/*sdfaf*/ \n"); 对其中的/**/之间的注释不做处理

     printf("adfasdf//adsfadsf//afdadsf\n");对其中的//注释也不做处理

5、对于换行符 \ 不做处理;

6、要求对于其中出现的空行要能够删除(这个我只实现了对于开头没有空格空行的删除,还需要改进的地方)


更具以上要求,对状态进行分析,得出以下的装态转换矩阵:




以下是对于这个的C语言代码实现(From是要删除注释的C文件名,To是删除后的文件名):

void removec(char* From,char* T
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值