解:(1)从这个例子中看出,Ashcroft_Manna 技术的基本方法是,当待改造的序含有嵌套的非结构化的IF语句时,改造后的程序中增加DO-CASE语句和DO-UNTIL语句,并增加一个辅助变量I,I的初始值为1。最外层的IF语句在I=1时执行,执行完这个IF语句后把I赋值为随后应该执行的内层IF语句所对应的CASE标号值。DO-CASE语句的最大分支数(可执行的最大标号值)等于IF语句的个数。当执行完最内层的IF语句之后,把I赋值为可执行的最大标号值加1,而DO-UNTIL 循环的结束条件就是I等于这个值。 (2)进一步简化后的结构化程序的流程图如下所示。
I=1 DO CASE=1 Te Fc TFd TFA B C D D E I=2 I=3 I=4 I=4 I=4 I=4 FI=4 T停止 开始FcTABFdTFcTCDDE停止 7、某交易所规定给经纪人的手续费计算方法如下:总手续费等于基本手续费加上与交易中的每股价格和股数有关的附加手续费。如果交易金额少于1000元,则基本手续费为交易金额的8.4%;如果交易总金额在1000元~10000元之间,则基本手续费为交易金额的5%,再加34元;如果金额超过10000元,则基本手续费为交易金额的4%加上134元。当每股售价低于14元时,附加手续费为基本手续费的5%,除非买进、卖出的股数不是100的倍数,在这种情况下附加手续费的9%。当每股售价在14元到25元之间时,附加手续费为基本手续费的2%,除非交易的股数不是100的倍数,在这种情况下附加手续费的6%。当每股售价超过25元时,如果交易的股数(即不是100的倍数),则附加手续费为基本手续费的4%,否则附加手续费为基本手续费的1%。 要求:
(1)用判定表表示手续费的计算方法。 (2)用判定数表示手续费的计算方法。
解:令P代表交易的总金额,Q代表每股的售价,n代表交易的股数。 (1)表示手续费计算方法的判定表如图所示
(2)表示手续费计算方法的判定树
8、画出下列伪码程序的流图,计算它的环形复杂度。你觉得这个程序的逻辑有什么问题吗? C EXAMPLE
LOOP:DO WHILE X>0 A=B+1 IF A>10 THEN X=A ELSE Y=Z END IF IF Y<5
THEN PRINT X,Y
ELSE IF Y=2
THEN GOTO LOOP
ELSE C=3 END IF END IF G=H+R END DO IF F>0
THEN PRINT G ELSE PRINT K END IF STOP
解:流程图:
STARTFZ>0TA=B+1A>10TX=AY<5TPrint X,YF
Y=ZF Y>=5TY=2FC=31234687109111111115
G=H+RFF>0TPrint GPrint K
stop
环形复杂度:
V(G)=结点E-弧数n+1=17-11+1=7=判断结点 +1=6 +1=7=封闭的区域数