阅读下列C程序,回答下列问题。

请画出上述程序控制流图,并计算其环路复杂度VG.。
正确答案及解析
正确答案
解析
控制流图

第二小题考查白盒测试用例设计方法之基本路径法。
涉及到知识点包括根据代码绘制控制流图、计算环路复杂度。
控制流图是描述程序控制流一种图示方式,它由节点和定向边构成。控制流图节点代表一个基本块,定向边代表控制流方向。其中要特别注意是,如果判断中条件表达式是复合条件,即条件表达式是由一个或多个逻辑运算符连接逻辑表达式,则需要改变复合条件判断为一系列之单个条件嵌套判断。本题程序中,if(month>=1 && month<=12)这条判断语句中判定由两个条件组成,因此在画控制流图时候需要拆开成两条判断语句。同理,if(month==4||month=6||month==9||month=11)这条判断语句中判定由4个条件组成,因此在画控制流图时候需要拆开成4条判断语句。这里需要注意是,如果复合条件之间是"&&"关系,则拆开后反应在控制流图上是沿左子树往下,反之如果条件之间是"||"关系,则在控制流图上是沿右子树往下。
程序环路复杂度等于控制流图中判定节点个数加1,本题控制流图中判定节点个数为10,所以V(G)=11。
你可能感兴趣的试题

-
- A.V(S2)和P(S4)
- B.P(S2)和V(S4)
- C.P(S2)和P(S4)
- D.V(S2)和V(S4)
- 查看答案

-
- A.V(S1)P(S2)和V(S3)
- B.P(S1)V(S2)和V(S3)
- C.V(S1)V(S2)和V(S3)
- D.P(S1)P(S2)和V(S3)
- 查看答案

-
- A.P(S4)和V(S4)V(S5)
- B.V(S5)和P(S4)P(S5)
- C.V(S3)和V(S4)V(S5)
- D.P(S3)和P(S4)V(P5)
- 查看答案

-
- A.P(S3)和V(S4)V(S5)
- B.V(S3)和P(S4)P(S5)
- C.P(S3)和P(S4)P(S5)
- D.V(S3)和V(S4)V(S5)
- 查看答案

-
- A.P(S2)和P(S4)
- B.P(S2)和V(S4)
- C.V(S2)和P(S4)
- D.V(S2)和V(S4)
- 查看答案