阅读下列系统设计说明,回答问题1至问题3,将解答填入答题纸的对应栏内。 【说明】 某玩具公司正在

阅读下列系统设计说明,回答问题1至问题3,将解答填入答题纸的对应栏内。 【说明】 某玩具公司正在开发一套电动玩具在线销售系统,用于向注册会员提供端对端的玩具 定制和销售服务。在系统设计阶段,"创建新订单 (New Order)" 的设计用例详细描述如表 3-1 所示,候选设计类分类如表 3-2 所示,并根据该用例设计出部分类图如图3-1所示。 表 3-1 创建新订单 (NewOrder) 设计用例 用例名称 创建新订单New Order 用例编号 ETM-R002 参与者 会员 前提条件 会员已经注册并成功登录系统 典型事件流 1.会员(C1)点击“新的订单”按钮; 2.系统列出所有正在销售的电动玩具清单及价格(C2) 3.会员点击复选框选择所需电动玩具并输入对应数量,点击“结算”按钮; 4.系统自动计算总价(C3), 显示销售清单和会员预先设置个人资料的收货地址和支付方式(C4); 5.会员点击“确认支付”按钮; 6.系统自动调用支付系统(C5)接口支付该账单; 7.若支付系统返回成功标识,系统生成完整订单信息持久存储到数据库订单表(C6)中; 8.系统将以表格形式显示完整订单信息(C7),同时自动发送完整订单信息(C8)至会员预先配置的邮箱地址(C9)。 候选事件流 3a (1)会员点击“定制”按钮; (2)系统以列表形式显示所有可以定制的电动玩具清单和定制属性(如尺寸、颜色等)(C10); (3)会员点击单选按钮选择所需要定制的电动玩具并填写所需要定制的属性要求,点击“结算”按钮; (4)回到步骤4. 7a (1)若支付系统返回失败标识,系统显示会员当前默认支付方式(C11)让会员确认; (2)若会员点击“修改付款”按钮,调用“修改付款”用例,可以新增并存储为默认支付方式(C12),回到步骤4; (3)若会员点击“取消订单”,则该用例终止执行。 表3-2 候选设计类分类 接口类(Interface,负责系统与用户之间的交互) (a) 控制类(Control,负责业务逻辑的处理) (b) 实体类(Entity,负责持久化数据的存储) (c)在订单处理的过程中,会员可以点击“取消订单"取消该订单。如果支付失败,该订单将被标记为挂起状态,可后续重新支付,如果挂起超时30分钟未支付,系统将自动取消该订单。订单支付成功后,系统判断订单类型: (1)对于常规订单,标记为备货状态,订单信息发送到货运部,完成打包后交付快递发货; (2)对于定制订单,会自动进入定制状态,定制完成后交付快递发货。会员在系统中点击”收货"按钮变为收货状态,结束整个订单的处理流程。根据订单处理过程所设计的状态图如图3-2所示。图3-2 订单状态图

【问题1】(6分) 根据表3-1中所标记的候选设计类,请按照其类别将编号 C1~C12 分别填入表 3-2 中的(a)、(b)和(c)处。 【问题2】 (4 分) 根据创建新订单的用例描述,请给出图3-1中X1~X4处对应类的名称。 【问题3】 (5分) 根据订单处理过程的描述,在图 3-2 中S1~S5处分别填入对应的状态名称。

请帮忙给出正确答案和分析,谢谢!

  • 悬赏:0 答案豆
  • 提问人:00****83
  • 发布时间:2017-09-30
您可能感兴趣的试题
阅读下列说明和C代码,回答问题 1 至问题 3,将解答写在答题纸的对应栏内。【说明】假币问题:有n枚硬币,其中有一枚是假币,己知假币的重量较轻。现只有一个天平,要求用尽量少的比较次数找出这枚假币。【分析问题】将n枚硬币分成相等的两部分:(1)当n为偶数时,将前后两部分,即 1...n/2和n/2+1...0,放在天平的两端,较轻的一端里有假币,继续在较轻的这部分硬币中用同样的方法找出假币:(2)当n为奇数时,将前后两部分,即1..(n -1)/2和(n+1)/2+1...0,放在天平的两端,较轻的一端里有假币,继续在较轻的这部分硬币中用同样的方法找出假币;若两端重量相等,则中间的硬币,即第 (n+1)/2枚硬币是假币。【C代码】下面是算法的C语言实现,其中:coins[]: 硬币数组first,last:当前考虑的硬币数组中的第一个和最后一个下标 #include int getCounterfeitCoin(int coins[], int first,int last){     int firstSum = 0,lastSum = 0;     int ì;     If(first==last-1){       /*只剩两枚硬币*/      if(coins[first]< coins[last])         return first;          return last;      } if((last - first + 1) % 2 ==0){      /*偶数枚硬币*/      for(i = first;i<(  1  );i++){            firstSum+= coins[i];       }       for(i=first + (last-first) / 2 + 1;i< last +1;i++){           lastSum += coins[i];       }       if(   2   ){           Return getCounterfeitCoin(coins,first,first+(last-first)/2;)       }else{           Return getCounterfeitCoin(coins,first+(last-first)/2+1,last;)       }}else{      /*奇数枚硬币*/       For(i=first;ilastSum){              return getCounterfeitCoin(coins,first+(last-first)/2-1,last);       }else{           Return(  3   )       }    }}

【问题一】

根据题干说明,填充C代码中的空(1)-(3)

【问题二】

根据题干说明和C代码,算法采用了(  )设计策略。

函数getCounterfeitCoin的时间复杂度为(  )(用O表示)。

【问题三】

若输入的硬币数为30,则最少的比较次数为( ),最多的比较次数为(  )。

阅读下列说明和 C++代码,将应填入(n)处的字句写在答题纸的对应栏内。【说明】某快餐厅主要制作井出售儿童套餐,一般包括主餐(各类比萨)、饮料和玩具,其餐品种类可能不同,但其制作过程相同。前台服务员(Waiter)调度厨师制作套餐。现采用生成器(Builder) 模式实现制作过程,得到如图 5-1 所示的类图。图5-1    类图【C++代码】#include#includeusing namespace std; class Pizza {private: string parts;public:  void setParts(string parts) {     this->parts=parts;  }   string getParts() {  return parts;   }};class PizzaBuilder {protected:Pizza* pizza;public:  Pizza* getPizza() {  retum pizza;  }   void createNewPizza() { pizza = new Pizza();     }     (   1   );}class HawaiianPizzaBuilder :public PizzaBuilder {public:    void buildParts() { pizza->setParts("cross +mild + ham&pineapple");   }};class SpicyPizzaBuider: public PizzaBuilder {public:    void buildParts() { pizza->setParts("pan baked +hot + ham&pineapple");    } } Class Waiter{Private:   PizzaBuilder* pizzaBuilder;public:   void setPizzaBuilder(PizzaBuilder* pizzaBuilder) {   /*设置构建器*/     (  2  )   }   Pizza* getPizza() {  return pizzaBuilder->getPizza(); }   void construct() {     /*构建*/       pizzaBuilder->createNewPizza();       (  3  )   } }; int main(){    Waiter*waiter=new Waiter();    PizzaBuilder*hawaiian pizzabuilder=new HawaiianPizzaBuilder() (   4  );(   5  );cout<< "pizza: "<< waiter->getPizza()->getParts()<< endl;}程序的输出结果为:pizza: cross + mild + ham&pineapple
阅读下列说明和 Java代码,将应填入 (n) 处的字句写在答题纸的对应栏内。【说明】某快餐厅主要制作并出售儿童套餐,一般包括主餐(各类比萨)、饮料和玩具,其餐品种类可能不同,但其制作过程相同。前台服务员 (Waiter) 调度厨师制作套餐。现采用生成器 (Builder) 模式实现制作过程,得到如图 6-1 所示的类图。【Java代码】class Pizza {    private String parts;    public void setParts(String parts) {     this.parts = parts; }    public String toString() {      return this.parts;   }} abstract class PizzaBuilder {    protected Pizza pizza;    public Pizza getPizza() { return pizza;  }    public void createNewPizza() {      pizza = new Pizza();     }    public  (1)   ;} class HawaiianPizzaBuilder extends PizzaBuilder {  public void buildParts() {     pizza.setParts("cross + mild + ham&pineapp1e”};} class SpicyPizzaBuilder extends PizzaBuilder {  public void buildParts() { pizza.setParts("pan baked + hot + pepperoni&salami");          }} class Waiter {    private PizzaBuilder pizzaBuilder;    public void setPizzaBuilder(PizzaBuilder pizzaBuilder) {  /*设置构建器*/                 ( 2 )    ;      }    public Pizza getPizza(){ return pizzaBuilder.getPizza(); }   public void construct() {      /*构建*/       pizzaBuilder.createNewPizza();        ( 3 )   ;      }} Class FastFoodOrdering {    public static viod mainSting[]args) {       Waiter waiter = new Waiter();       PizzaBuilder hawaiian_pizzabuilder = new HawaiianPizzaBuilder();        ( 4 )    ;       ( 5 )    ;      System.out.println("pizza: " + waiter.getPizza());      }} 程序的输出结果为:Pizza:cross + mild + ham&pineapple

继续查找其他问题的答案?

请先输入下方的验证码查看最佳答案

图形验证:看不清?点击更换 换一换
免验证查看
开通上学吧会员
已为用户解答试题的人次:
1511286425
选择会员套餐:
推荐
¥39.8
1.3元/天
1个月
¥49.8
¥100
3个月
¥99.8
¥200
1年
选择支付方式:
微信付款
支付宝付款
会员特权: 会员须知
可退款
账号未使用的话,支持退款
免注册
支付后,系统自动注册账号给您
无限看题
不限次数随时看题
智能搜题
下载APP,可拍照、语音搜题
随时随地
电脑、手机、平板均可使用
免广告
纯净体验,自动屏蔽广告
开通上学吧会员
已为用户解答试题的人次:
1511286425
已选择:
请使用微信扫码支付¥49.8
订单号:
更改套餐或支付方式
会员特权: 会员须知
可退款
账号未使用的话,支持退款
免注册
支付后,系统自动注册账号给您
无限看题
不限次数随时看题
智能搜题
下载APP,可拍照、语音搜题
随时随地
电脑、手机、平板均可使用
免广告
纯净体验,自动屏蔽广告
恭 喜 您 获 得
扫 码 免 费 领 取
会 员 或 搜 题 次 数
本弹窗关闭将不再弹出
请不要关闭本页面,支付完成后请点击【支付完成】按钮
遇到问题请联系在线客服
常用手机号:
用于找回密码
图片验证码:
看不清?点击更换
短信验证码:
新密码:
 
绑定后可用手机号登录
谢谢您的反馈

您认为本题答案有误,我们将认真、仔细核查,如果您知道正确答案,欢迎您来有偿纠错