亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 1934 | 回復: 3
打印 上一主題 下一主題

去除左遞歸的問題 [復制鏈接]

論壇徽章:
0
跳轉到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2013-05-20 12:58 |只看該作者 |倒序瀏覽
請教有關C語法的問題

1、對于C語言語法里的 declarator 和 abstract_declarator,以及其相關的direct_declarator 和 direct_abstract_declarator 的C語言語法如下:

=============================================================================================
1)declarator
        : pointer direct_declarator
        | direct_declarator
        ;

2)direct_declarator
        : IDENTIFIER
        | '(' declarator ')'
        | direct_declarator '[' constant_expression ']'
        | direct_declarator '[' ']'
        | direct_declarator '(' parameter_type_list ')'
        | direct_declarator '(' identifier_list ')'
        | direct_declarator '(' ')'
        ;

3)abstract_declarator
        : pointer
        | direct_abstract_declarator
        | pointer direct_abstract_declarator
        ;

4)direct_abstract_declarator
        : '(' abstract_declarator ')'
        | '[' ']'
        | '[' constant_expression ']'
        | direct_abstract_declarator '[' ']'
        | direct_abstract_declarator '[' constant_expression ']'
        | '(' ')'
        | '(' parameter_type_list ')'
        | direct_abstract_declarator '(' ')'
        | direct_abstract_declarator '(' parameter_type_list ')'
        ;

============================================================================================


2、對于以上4條語法,在去左遞歸后,變?yōu)槿缦拢?/strong>
============================================================================================
1)declarator不存在左遞歸

2)direct_declarator        : IDENTIFIER R
                        | '(' declarator ')' R
                        ;

                R        : '[' constant_expression ']' R
                        | '[' ']' R
                        | '(' parameter_type_list ')' R
                        | '(' identifier_list ')' R
                        | '(' ')' R
                        | Ɛ
                        ;                                       

3)abstract_declarator不存在左遞歸,但為了方便分析,轉換為如下:

abstract_declarator        : A B
                        ;

                A        : pointer
                        | Ɛ
                        ;

                B        : direct_abstract_declarator
                        | Ɛ
                        ;

4)direct_abstract_declarator        : '(' abstract_declarator ')' R
                                | '[' ']' R
                                | '[' constant_expression ']' R
                                | '(' ')' R
                                | '(' parameter_type_list ')' R
                                                                ;

                        R         : '[' ']' R
                                | '[' constant_expression ']' R
                                | '(' parameter_type_list ')' R
                                | '(' ')' R
                                | Ɛ
                                ;       
============================================================================================


3、問題


1)對于上面第2中的2)、4)的“去左遞歸”的轉換是否正確?

論壇徽章:
0
2 [報告]
發(fā)表于 2013-05-20 13:00 |只看該作者
回復 1# landker

ding
   

論壇徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11數(shù)據(jù)庫技術版塊每日發(fā)帖之星
日期:2016-08-03 06:20:00數(shù)據(jù)庫技術版塊每日發(fā)帖之星
日期:2016-08-04 06:20:00
3 [報告]
發(fā)表于 2013-07-02 14:25 |只看該作者
回復 1# landker
正確

論壇徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:53:17
4 [報告]
發(fā)表于 2013-07-03 16:21 |只看該作者
2)

direct_declarator
  : IDENTIFIER
  | '(' declarator ')'
  | IDENTIFIER R
  | '(' declarator ')' R
  ;

R
  : '[' constant_expression ']'
  | '[' ']'
  | '(' parameter_type_list ')'
  | '(' identifier_list ')'
  | '(' ')'
  | '[' constant_expression ']' R
  | '[' ']' R
  | '(' parameter_type_list ')' R
  | '(' identifier_list ')' R
  | '(' ')' R
  ;

讓規(guī)則R不可匹配空規(guī)則,這樣寫還對么?
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復

  

北京盛拓優(yōu)訊信息技術有限公司. 版權所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關心和支持過ChinaUnix的朋友們 轉載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP