1014 我的C语言文法定义与C程序推导过程

程序> -> <外部声明> | <程序> <外部声明>

<外部声明> -> <函数定义> | <声明>

<函数定义> -> <类型说明> <声明符> <复合语句>

<类型说明> -> <void> | <char> | <int>|<float>

<声明> ->  <指针>  <直接说明符>  |  <直接说明符>

<指针> -> <*> | <*指针>

<直接说明符> -> <标识符>  | <直接说明符  ‘[‘  ‘]‘> | <直接标识符‘[‘ 恒表达‘]‘> | <标识符‘(‘ 参数名单 ‘)‘> | <标识符‘(‘ ‘)‘> | <直接说明符 ‘;‘ 识别名单>

<识别名单> -> <标识符> |  <识别名单 ‘;‘ 标识符>

<恒表达式> -> <恒表达式>

<参数名单> -> <参数声明> | <参数名单 ‘;‘ 参数声明>

<参数声明>-><‘说明符‘ ‘声明‘ ‘标识符‘>

<复合语句>-> <‘{‘ ‘}‘> | <‘{‘语句列表‘}‘> | <‘{‘声明‘ ‘语句列表‘ ‘}‘>

<声明_列表> -> <识别符> | <识别名单 识别符>

<识别符> -> <初始化标别符> |<初始化标识符 ‘,‘ 初始化标识符>

<初始化标识符> -> <标识符> | <标识符 ‘=‘ 初始化器>

<初始化器> -> <赋值表达式> | <‘{‘  初始化列表 ‘}‘> | <‘{‘ 初始化列表 ‘,‘ ‘}‘>

<初始化列表> -> <初始化>| <初始化列表 ‘,‘ 初始化器>

<语句表> -> <语句> | <语句表 语句>

<语句> -> |<复合语句> |<表达式语句>|<选择语句>|<迭代语句>|<跳转语句>

<表达式语句> -> -><表达式 ‘;‘>

<选择语句> :if< ‘(‘ 表达式‘)‘ 语句> | if <‘(‘ 表达式 ‘)‘ 语句 else语句 >

<迭代语句> -> while< ‘(‘ 表达式 ‘)‘ 语句 >| for‘(‘ 表达语句 表达语句 ‘)‘ 语句 | for‘(‘ 表达语句 表达语句 表达式 ‘)‘ 语句

<跳转语句> -> <continue>|<break>|<return>|<return 表达式>

<表达式> -> <赋值表达式>|<表达式,赋值表达式>

<赋值表达式> -><条件表达式>|<一元表达式赋值运算符  赋值表达式>

<条件表达式> -> <逻辑或表达>|<逻辑或表达‘?‘ 表达式 ‘:‘条件表达式>

<逻辑或表达> -><逻辑与表达> |<逻辑或表达或运算逻辑表达式>

<逻辑与表达> -><或运算表达式>|< 逻辑表达式和运算或表达式>

<或运算表达式> -><异或表达式>|<或运算表达式 ‘|‘ 异或表达式>

<异或表达式> :<与表达式> | <异或表达式‘^‘与表达式>

<与表达式> :<相等表达式>|<与表达式‘&‘相等表达式>

<相等表达式> :<关系表达式> |< 相等表达式等于运算关系表达式> |< 相等表达式不等于运算关系表达式>

<关系表达式> :<移位表达式>|<关系表达式‘<‘移位表达式>|<关系表达式‘>‘移位表达式 >|< 关系表达式小于等于运算移位表达式>|<关系表达式大于等于运算移位表达式>

<移位表达式> :<加法表达式> |< 移位表达式左运算加法表达式 > |< 移位表达式右运算加法表达式>

<加法表达式> :<乘法表达式> | <加法表达式‘+‘乘法表达式 >|< 加法表达式‘-‘乘法表达式>

<乘法表达式> :<强制转换表达式> | <乘法表达式‘*‘强制转换表达式> | <乘法表达式‘/‘强制转换表达式> |<乘法表达式‘%‘强制转换表达式>

<强制转换表达式> :<一元表达式 > | < ‘(‘ 类型名称 ‘)‘强制转换表达式>

<一元表达式> <后缀表达式>|< inc运算一元表达式>|< dec运算一元表达式>|< 一元运算符将表达式>| <结构体变量的一元表达式>| <结构体变量的‘(‘ 类型名称 ‘)‘>

<后缀表达式> :<基本表达式> | <后缀表达式‘[‘表达式‘]‘> | <后缀表达式‘(‘ ‘) >|<后缀表达式 ‘(‘参数表达式列表‘)‘  >|< 后缀表达式‘.‘ 标识符 >| <后缀表达式指针运算标识符 >| <后缀表达式inc运算 >| <后缀表达式dec运算>

<基本表达式> -> <标识符> |< 常量>|< 字符串常量> |< ‘(‘表达式‘)‘>

<参数表达式列表> : <赋值表达式>| <参数表达式列表‘,‘赋值表达式>

<一元运算符> :< ‘&‘>  | < ‘*‘ > |  <‘+‘ > | < ‘-‘>  | < ‘~‘>  | < ‘!‘>

<赋值运算符> -> <‘=‘ > |< 乘法分配> |< div分配>| <mod分配> | <加法分配>  |  <sub分配 > |< 左分配> | <右分配> |< 与分配> |< 异或分配> |< 或分配>

<存储类说明符> -> <定义类型> |< 外部变量> | <静态 > |< 自动>  |< 寄存器>

<结构或联合说明符> :<结构或联合标识符‘{‘结构体声明列表‘}‘ > | <结构或联合‘{‘结构体声明列表‘}‘  >|< 结构或联合标识符>

<结构或联合> :<结构体> |< 联合>

<结构体声明列表> <结构体声明> |< 结构体声明结构体声明列表>

<结构体声明> :<说明符限定符列表结构说明符‘;‘说明符->类型说明符说明符限定符列表 >| <类型说明符 >| <类型限定符说明符限定符列表> |< 类型限定符>

<结构说明符列表> -> <结构体声明>| <结构说明符列表‘,‘结构体声明>

<结构体声明> -> :<声明> |<  ‘:‘常量表达式>|< 声明‘:‘常量表达式>

<枚举声明> -> <枚举‘{‘枚举器列表‘}‘ >| <枚举标识符‘{‘枚举器列表‘}‘ > |< 枚举标识符>

<枚举器列表> -> <枚举器> |< 枚举器列表‘,‘枚举器>

<枚举器> -> <标识符> |< 标识符‘=‘常量表达式>

<类型限定符> -> <常量> |< 易失的>

<类型限定符列表> -> <类型限定符> |< 类型限定符列表  类型限定符>

<参数类型列表> -> <参数列表> |< 参数列表‘,‘省略符号>

<参数列表> -> <声明参数> | <参数列表‘,‘声明参数>

<类型名称> -> <限定说明符列表> |< 限定符抽象说明符列表>

<抽象说明符> -> <指针> |<直接抽象说明符> |< 指针直接抽象说明符>

<直接抽象说明符> -> <‘(‘ 抽象说明符 ‘)‘ >| <‘[‘ ‘]‘  |  ‘[‘ 常量表达式‘]‘>| <直接抽象说明符‘[‘ ‘]‘ > | <直接抽象说明<符‘[‘ 常量表达式 ‘]‘ > | < ‘(‘ ‘)‘  |  ‘(‘参数类型列表‘)‘ >|< 直接抽象说明符‘(‘ ‘)‘> | <直接抽象说明符‘(‘参数类型列表‘)‘>

<有标号语句> -> <标识符‘:‘语句> | <case常量表达式‘:‘语句>  | < default‘:‘语句>

时间: 2024-12-18 19:46:42

1014 我的C语言文法定义与C程序推导过程的相关文章

1014 C语言文法定义与C程序的推导过程 程序:冒泡算法C程序(语法树)

1014 C语言文法定义与C程序的推导过程  程序:冒泡算法C程序(语法树)1 阅读并理解提供给大家的C语言文法文件. 2 参考该文件写出一个自己好理解版的现实版的完整版的C语言文法. 3 给出一段C程序,画出用上述文法产生这段C程序的完整语法树. 程序:冒泡算法C程序 点此文字查看原图(完整图片) 1 #include <stdio.h> 2 3 main() 4 { 5 int i,j,temp; 6 int a[10]; 7 8 for(i=0;i<10;i++) 9 scanf

1014 C语言文法定义与C程序的推导过程

<程序>-><外部声明>|<程序><外部声明> <外部声明>-><函数定义>|<定义> <函数定义>-><类型说明><声明><复合语句> <类型说明>->无返回型|字符型|整型|单精度型 <声明>-><指针直接说明符>|<直接说明符> <指针>-><’*’>|<’

1106 1014 C语言文法定义与C程序的推导过程 冒泡程序语法树

C语言文法定义与C程序的推导过程

program à external_declaration | program external_declaration <程序> ->  <外部声明> |  <程序>  <外部声明> external_declaration à function_definition | declaration <外部声明>  ->   <函数定义>  |  <声明> function_definition à type_

C语言文法定义及C程序的推导过程

program à external_declaration | program external_declaration <程序> ->  <外部声明> |  <程序>  <外部声明> external_declaration à function_definition | declaration <外部声明>  ->   <函数定义>  |  <声明> function_definition à type_

1029 C语言文法定义与C程序的推导过程

program à external_declaration | program external_declaration 程序→ <外部声明> | <程序> <外部声明> external_declaration à function_definition | declaration       外部声明→ <函数定义> | <声明> function_definition à type_specifier declarator compoun

C语言文法定义及推导

文法推导如下: <程序>→ <外部声明>|<程序><外部声明><外部声明>→ <函数定义>|<声明><函数定义>→ <类型说明><声明符><复合语句><类型说明>→void|char|int|float...<声明符>→<指针直接说明符>|<直接声明符><指针>→<*>|<* *><直接

1014--C语言文法定义

<程序>-><外部声明>|<程序><外部声明> <外部声明>-><函数定义>|<定义> <函数定义>-><类型说明><声明><复合语句> <类型说明>->无返回型|字符型|整型|单精度型 <声明>-><指针直接说明符>|<直接说明符> <指针>-><’*’>|<’

1029 C语言文法定义

program à external_declaration | program external_declaration <源程序> ->  <外部声明> |  <源程序>  <外部声明> external_declaration à function_definition | declaration <外部声明>  ->   <函数定义>  |  <声明> function_definition à typ