【问题标题】:Write EBNF form for a year/month/day写一年/月/日的EBNF表格
【发布时间】:2016-03-13 14:07:26
【问题描述】:

我想找到下一个问题的解决方案,但是我需要将时间的EBNF写成年-月-日和月-日-年两种格式,以查看差异:

确定将日期写为结构化整数的一个优势:年、月、日 (1954-02-10),而不是按正常顺序 (02-10-1954)。

格式:年-月-日。 这是我想出的:

<NonZeroDigit> ::= ("1" | "2" | ... | "9")
<Month> ::= ( "0" <NonZeroDigit> ) | ( "1" ( "0" | "1" | "2" ) ) 
<Day> ::= ( "0" <NonZeroDigit> ) | ( ("1" | "2") <NonZeroDigit> ) | ("3" ( "0" | "1" ) )
<Year> ::= ( "000" <NonZeroDigit> ) | 
            ( "00" <NonZeroDigit> <NonZeroDigit> ) | 
            ( "0" <NonZeroDigit> <NonZeroDigit> <NonZeroDigit> ) | 
            ( "1"  <NonZeroDigit> <NonZeroDigit> <NonZeroDigit>) |
            ( "20" <NonZeroDigit> <NonZeroDigit> ) )

这一年是 2099 年,我想这还可以,这些规则有效,但是当时有没有更好的方法来编写 EBNF? 我错过了什么吗?

【问题讨论】:

  • 您可以允许一个日期,例如 2 月 31 日吗?如果是这样,您可以通过定义 ::= | 来简化。 “0”,让年份有四个数字。您将一直到 9999 年。否则,您将不得不辨别具有 28、30、31 天的月份。二月有 29 天的闰年呢?
  • 是的,忘记那些东西了哈哈。将再次检查。但我在正确的轨道上?
  • 是的。这一切都是为了获得正确的分组,而不是过多地重复自己。还有一件事:当您将它们放在一起定义 时,您可能需要包含破折号“-”

标签: context-free-grammar ebnf context-free-language


【解决方案1】:

所以我想出的解决方案是这样的:

<FebruaryNum> ::= "02"
<Dash> ::= "-"
<NonLeapDigit> ::= "1" | "2" | "3" | "5" | "6" | "7"
<LeapDigit> ::= "4" | "8"
<NonZeroOrNineDigit> ::= <NonLeapDigit> | <LeapDigit>
<Digit> ::= "0" | <NonZeroOrNineDigit> | "9"
<ThreeDigits> ::= <Digit> <Digit> <Digit>
<DaysFebNonLeap> ::= ( "0" <Digit> ) | ( ("1" | "2" ) ( <NonZeroOrNineDigit> | "0")
<DaysFebLeap> ::= <DaysFebNonLeap> | "29"
<Days30> ::= <DaysFebLeap> | "30"
<Days31> ::= <Days30> | "31" 
<LeapYear> ::= <ThreeDigits> ( <LeapDigit> | "0" )
<NonLeapYear> ::= <ThreeDigits> ( "0" | <NonLeapDigit> | "9" )
<Month31Days> ::= ( ( "0" ( "1" | "3" | "5" | "7" | "8") ) | ( "1" ( "0" | "2" ) ) ) <Dash> <Days31>
<Month30Days> ::= ( ( "0" ( "4" | "6" | "9" ) ) | "11" ) <Dash> <Days30> 
<FebruaryLeap> ::= <FebruaryNum> <Dash> <DaysFebLeap>
<FebruaryNonLeap> ::= <FebruaryNum> <Dash> <DaysFebNonLeap>

<DateYearMonthDay> ::= ( <LeapYear> <Dash> ( <FebruaryLeap> | <Month30Days> | <Month31Days> ) ) | 
                        ( <NonLeapYear> <Dash> ( <FebruaryNonLeap> | <Month30Days> | <Month31Days> ))

当你写年-月-日而不是日-月-年或月-日-年时,你得到的好处是,日取决于月,月取决于年,因此更容易编写自动机可以以年-月-日格式打印日期。

【讨论】:

    猜你喜欢
    • 2013-06-20
    • 2015-02-03
    • 2015-04-29
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-02-27
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多