[说明] 任何一种程序都是为了解决问题而撰写的,解决问题时需要实现一些特定的运算法

题型:问答题

问题:

[说明]
任何一种程序都是为了解决问题而撰写的,解决问题时需要实现一些特定的运算法则。在策略(Strategy)模式下,可以更换实现算法的部分而不留痕迹,切换整个算法,简化改为采用其他方法来解决同样问题。
以下是一个“剪刀石头布”游戏。猜拳时的“策略”有2种方法:第一种是“猜赢后继续出同样的招式”(WinningStrategy),第二种是“从上一次出的招式种,以概率分配方式求出下一个招式的几率”(ProbStrategy)。程序中定义了Hand类表示猜拳时的“手势”,类内部以0(石头)、1(剪刀)、2(布)来表示。Hand类的实例只会产生3个。
以下是Java语言实现,省略了不相关属性及方法,方法实现体亦有所省略,能够正确编译通过。
[Java代码]
//Hand.java文件
public class Hand
public static final int HANDVALUE_GUU = 0; //石头
public static final int HANDVALUE_CHO = 1; //剪刀
public static final int HANDVALUE_PAA = 2; //布
public static final Hand[] hand =
new Hand(HANDVALUE_GUU),
new Hand(HANDVALUE_CHO),
new Hand(HANDVALUE_PAA),
;
private int handvalue;
(1) Hand(int handvalue)
this.handvalue = handvalue;

public (2) Hand getHand(int handvalue)(//从值取得对象实例
return hand[handvalue];


//Strategy.java文件
public interface Strategy
public (3) Hand nextHand();

//ProbStrategy.java文件
import java.util.Random;
public class ProbStrategy implements Strategy
public Hand nextHand()
int handvalue = 0;
/*省略具体实现*/
return Hand.getHand(handvalue);


//WinningStrategy.java文件
import java.util.Random;
public class WinningStrategy implements Strategy
/*省略了不相关属性*/
public Hand nextHand()
if(!won)
prevHand = Hand.getHand(random.nextInt(3));

return prevHand;


//Player.java文件
public class Player
private String name;
private Strategy strategy;
public Player(String name, (4) strategy)
this.name = name;
this.strategy = strategy;

public Hand nextHand()//向战略请示手势
return (5) ;


考点:计算机软件水平考试中级软件设计师中级软件设计师下午试题
题型:问答题

把两根底面积相等的2米长的圆柱体拼成一根圆柱体钢材以后,表面积减少了0.6平方分米,如果每立方分米钢材重7.8千克,拼成后的这根钢材重多少千克?

题型:问答题

下列哪项因素与新生儿坏死性小肠结肠炎发病关系最密切()

A.寒冷

B.溶血

C.配方奶喂养

D.早产

E.双胎或多胎

题型:问答题

以下每名患者都可以由李医生负责治疗,除了哪一位EGIK

A.E

B.G

C.I

D.K

题型:问答题

在肺炎双球菌转化实验中,将R型活细菌与加热杀死的S型细菌混合后,注射到小鼠体内,能在小鼠体内出现的细菌类型有()

①有毒R型

②无毒R型

③有毒S型

④无毒S型

A.①④

B.②③

C.③

D.①③

题型:问答题

有关流行性腮腺炎的流行病学,正确的是()

A.以1岁以下婴儿多见

B.以冬、春季为主

C.主要通过飞沫传播

D.早期病人和隐性感染者为传染源

E.有脑膜炎表现者可从脑脊液中分离出病毒

更多题库