中級軟件設(shè)計師2017上半年下午試題及答案解析_第1頁
中級軟件設(shè)計師2017上半年下午試題及答案解析_第2頁
中級軟件設(shè)計師2017上半年下午試題及答案解析_第3頁
已閱讀5頁,還剩15頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、試題一(15分)閱讀下列說明和圖,回答問題1至問題4。某醫(yī)療器械公司作為復(fù)雜醫(yī)療產(chǎn)品的集成商,必須保持高質(zhì)量部件的及時供應(yīng)。為了實現(xiàn)這一目標(biāo),該公司欲開發(fā)一采購系統(tǒng)。系統(tǒng)的主要功能如下:1檢查庫存水平。采購部門每天檢查部件庫存量,當(dāng)特定部件的庫存量降至其訂貨點時,返回低存量部件及庫存量。2下達采購訂單。采購部門針對低存量部件及庫存量提交采購請求,向其供應(yīng)商(通過供應(yīng)商文件訪問供應(yīng)商數(shù)據(jù))下達采購訂單,并存儲于采購訂單文件中。3. 交運部件。當(dāng)供應(yīng)商提交提單并交運部件時,運輸和接收(S/R)部門通過執(zhí)行以下三步過程接收貨物:(1驗證裝運部件。通過訪問采購訂單并將其與提單進行比較來驗證裝運的部件,

2、并將提單信息發(fā)給S/R職員。如果收貨部件項目出現(xiàn)在采購訂單和提單上,則已驗證的提單和收貨部件項目將被送去檢驗。否則,將S/R職員提交的裝運錯誤信息生成裝運錯誤通知發(fā)送給供應(yīng)商。(2)檢驗部件質(zhì)量。通過訪問質(zhì)量標(biāo)準(zhǔn)來檢查裝運部件的質(zhì)量,并將己驗證的提單發(fā)給檢驗員。如果部件滿足所有質(zhì)量標(biāo)準(zhǔn),則將其添加到接受的部件列表用于更新部件庫存。如果部件未通過檢查,則將檢驗員創(chuàng)建的缺陷裝運信息生成缺陷裝運通知發(fā)送給供應(yīng)商。(3)更新部件庫存。庫管員根據(jù)收到的接受的部件列表添加本次采購數(shù)量,與原有庫存量累加來更新庫存部件中的庫存量。標(biāo)記訂單采購?fù)瓿伞,F(xiàn)采用結(jié)構(gòu)化方法對該采購系統(tǒng)進行分析與設(shè)計,獲得如圖1-1所示

3、的上下文數(shù)據(jù)流圖和圖1-2所示的0層數(shù)據(jù)流圖。員單飴思一vn事汝;就購曲按VfKfK存揶件用毒存礙購啾求員單飴思一1悶;存件茂暉祚r畢神T事一Kl1-上卜文養(yǎng)IttiAIT1-1上下文數(shù)據(jù)流圖胃掃鼎tarMigahA1-20層數(shù)據(jù)流圖1使用說明中的詞語,給出圖1-1中的實體E1E5(5分)2使用說明中的詞語,給出圖1-2中的數(shù)據(jù)存儲D1D4的名稱。(4分)3根據(jù)說明和圖中術(shù)語,補充圖1-2中缺失的數(shù)據(jù)流及其起點和終點。(4分)4用200字以內(nèi)文字,說明建模圖1-1和圖1-2時如何保持數(shù)據(jù)流圖(2分)試題二(15)1至問題3,將解答填入答題紙的對應(yīng)欄內(nèi)。某房屋租賃公司擬開發(fā)一個管理系統(tǒng)用于管理其

4、持有的房屋、租客及員工信息。請根據(jù)下述需求描述完成系統(tǒng)的數(shù)據(jù)庫設(shè)計。【需求描述】1、公司擁有多幢公寓樓,每幢公寓樓有唯一的樓編號和地址。每幢公寓樓中有(不同公寓樓內(nèi)的公寓號可相同)。系統(tǒng)需記錄每套公寓的臥室數(shù)和衛(wèi)生間數(shù)。2、員工和租客在系統(tǒng)中有唯一的編號(員工編號和租客編號)。3、對于每個租客,系統(tǒng)需記錄姓名、多個聯(lián)系電話、一個銀行賬號(方便自動扣房租)、一個緊急聯(lián)系人的姓名及聯(lián)系電話。4、系統(tǒng)需記錄每個員工的姓名、一個聯(lián)系電話和月工資。員工類別可以是經(jīng)理或維修工,也可兼任。每個經(jīng)理可以管理多幢公寓樓。每幢公寓樓必須由一個經(jīng)理管理。系統(tǒng)需記錄每個維修工的業(yè)務(wù)技能,比如:水暖維修,電工,木工等。

5、5、租客租賃公寓必須和公司簽訂租賃合同。一份租賃合同通常由一個或多個租客(合租)與該公寓樓的經(jīng)理簽訂,一個租客也可租賃多套公寓。合同內(nèi)容應(yīng)包含簽訂日期,開始時間,租期,押金和月租金。【概念模型設(shè)計】根據(jù)需求階段收集的信息,設(shè)計的實體聯(lián)系圖(不完整)如圖2-1所示【邏輯結(jié)構(gòu)設(shè)計】根據(jù)概念模型設(shè)計階段完成的實體聯(lián)系圖,得出如下關(guān)系模式(不完整):聯(lián)系電話(電話號碼,租客編號)租客(租客編號,姓名,銀行賬戶,聯(lián)系人姓名,聯(lián)系人電話)員工(員工編號,姓名,聯(lián)系電話,類別,月工資,(a)公寓樓(b),地址,經(jīng)理編號)c),押金)公寓(樓編號,公寓號,臥室數(shù),衛(wèi)生間數(shù))合同(合同編號,租客編號,樓編號,公

6、寓號,經(jīng)理編號,簽訂日期,起始日期,(1補充圖2-1中的簽約”聯(lián)系所關(guān)聯(lián)的實體及聯(lián)系類型。(4.5分)2補充邏輯結(jié)構(gòu)設(shè)計中的(a)、(b)、(c)三處空缺。(4.5分)3在租期內(nèi),公寓內(nèi)設(shè)施如出現(xiàn)問題,租客可在系統(tǒng)中進行故障登記,填寫故障描述,每項故障由系統(tǒng)自動生成唯一的故障編號,由公司派維修工進行故障維修,系統(tǒng)需記錄每次維修的維修日期和維修內(nèi)容。根據(jù)此需求,對圖2-1進行補充,并將所補充的ER圖內(nèi)容轉(zhuǎn)換為一個關(guān)系模式,請給出該關(guān)系模式。試題三(15分)1至問題3,將解答填入答題紙的對應(yīng)欄內(nèi)。某玩具公司正在開發(fā)一套電動玩具在線銷售系統(tǒng),用于向注冊會員提供端到端的玩具定制和銷售服務(wù)。在系統(tǒng)設(shè)計階

7、段,創(chuàng)建新訂單(NewOrder)的設(shè)計用例詳細描述如表3-1所示,候選設(shè)計類分類如表3-2所示,并根據(jù)該用例設(shè)計出部分類圖如圖3-1所示。表3-1創(chuàng)建新訂單(NewOrder)設(shè)計用例用例名稱創(chuàng)建新訂單NewOrder用例編號ETM-R002參與者會員前提條件會員已經(jīng)注冊并成功登錄系統(tǒng)1會員(C1點擊新的訂單”按鈕;典型事件流2系統(tǒng)列出所有正在銷售的電動玩具清單及價格(C23. 會員點擊復(fù)選框選擇所需電動玩具并輸入對應(yīng)數(shù)量,點擊結(jié)算”按鈕;4. 系統(tǒng)自動計算總價(C3,顯示銷售清單和會員預(yù)先設(shè)置個人資料的收貨地址和支付方式(C4;5. 會員點擊確認支付”按鈕;6. 系統(tǒng)自動調(diào)用支付系統(tǒng)(C5

8、接口支付該賬單;7. 若支付系統(tǒng)返回成功標(biāo)識,系統(tǒng)生成完整訂單信C6中;8. 系統(tǒng)將以表格形式顯示完整訂單信息(C7,同(C8至?xí)T預(yù)先配置的郵C9。3a(1)會員點擊定制”按鈕;(2)系統(tǒng)以列表形式顯示所有可以疋制的電動玩具候選事件流清單和定制屬性(如尺寸、顏色等)(C10;(3)會員點擊單選按鈕選擇所需要定制的電動點擊結(jié)算”4)回到步驟4。7a(1)若支付系統(tǒng)返回失敗標(biāo)識,系統(tǒng)顯示會員當(dāng)前默認支付方式(C11讓會員確認;(2)若會員點擊修改付款”按鈕,調(diào)用修改付款”用例,可以新增并存儲為默認支付方式C12,回到步驟4;(3若會員點擊取消訂單”,則該用例終止執(zhí)3-2候選設(shè)計類分類Interf

9、ace負責(zé)系統(tǒng)與用戶之間的(a)Control負責(zé)業(yè)務(wù)邏輯的處理)(b)在訂單處理的過程中,會員可以點擊取消訂單取消該訂單。如果支付失敗,該訂單將被標(biāo)記為掛起狀態(tài),可后續(xù)重新支付,如果掛起超時30分鐘未支付,系統(tǒng)將自動取消該訂單。訂單支付成功后,系統(tǒng)判斷訂單類型:(1) 對于常規(guī)訂單,標(biāo)記為備貨狀態(tài),訂單信息發(fā)送到貨運部,完成打包后交付;快遞發(fā)貨(2) 對于定制訂單,會自動進入定制狀態(tài),定制完成后交付快遞發(fā)貨。會員在系統(tǒng)中點擊”收貨按鈕變?yōu)槭肇洜顟B(tài),結(jié)束整個訂單的處理流程。根據(jù)訂單處理過程所設(shè)計的狀態(tài)圖如圖3-2所示。1根據(jù)表3-1中所標(biāo)記的候選設(shè)計類,請按照其類別將編號C1C1分別填入3-2

10、中的(a)、(b)和(c)處。(6分)2根據(jù)創(chuàng)建新訂單的用例描述,請給出圖3-1中X1X4處對應(yīng)類的名稱。(4分)3根據(jù)訂單處理過程的描述,在圖3-2中S1S5i分別填入對應(yīng)的狀態(tài)名稱。(5分)試題四:C代碼,回答冋題1至冋題3,將解答寫在答題紙的對應(yīng)欄內(nèi)。假幣問題n枚硬幣,其中有一枚是假幣,己知假幣的重量較輕。現(xiàn)現(xiàn)只有一個天平,要求用盡量少的比較次數(shù)找出這枚假幣。【分析問題】將n枚硬幣分成相等的兩部分:(1當(dāng)n為偶數(shù)時,將前后兩部分,即1n/2和n/2+1n,放在天平的兩端,較輕的一端里有假幣,繼續(xù)在較輕的這部分硬幣中用同樣的方法找出假幣:(2)當(dāng)n為奇數(shù)時,將前后兩部分,即1.(n-1)/

11、2和(n+1)/2+1.n,放在天平的兩端,較輕的一端里有假幣,繼續(xù)在較輕的這部分硬幣中用同樣的方法找出假幣:若兩端重量相等,則中間的硬幣,即第(n+1)/2枚硬幣是假幣。【C代碼】下面是算法的C語言實現(xiàn),其中:coins:硬幣數(shù)組first,last:當(dāng)前考慮的硬幣數(shù)組中的第一個和最后一個下標(biāo)#includeintgetCounterfeitCoin(intcoinintfirst,intlast)intfirstSum=0,lastSum=0;inti;if(first=last-1)/*只剩兩枚硬幣*/if(coinsfirstcoinslast)returnfirst;returnla

12、st;if(last-first+1)%2=0)/*偶數(shù)枚硬幣*/for(i=first;i(1);i+)firstSum+=coinsi;for(i=first+(last-first)/2+1;ilast+1;i+)lastSum+=coinsi;if(2)ReturngetCounterfeitCoin(coins,first,first+(last-first)/2;)elseReturngetCounterfeitCoin(coins,first+(last-first)/2+1,last;)else/*奇數(shù)枚硬幣*/for(i=first;ifirst+(last-first)/2

13、;i+)firstSum+=coinsi;for(i=first+(last-first)/2+1;ilast+1;i+)lastSum+=coinsi;if(firstSumlastSum)returngetCounterfeitCoin(coins,first+(last-first)/2-1,last);elsereturn(3)1根據(jù)題干說明,填充C代碼中的空(1)-(3)2根據(jù)題干說明和C代碼,算法采用了()設(shè)計策略。函數(shù)getCounterfeitCoi的時間復(fù)雜度為()(用0表示)。3若輸入的硬幣數(shù)為30,則最少的比較次數(shù)為(),最多的比較次數(shù)為()試題五(共15分)(請從試題五

14、、試題六中選答一題)閱讀下列說明和C+代碼,將應(yīng)填入(n)處的字句寫在答題紙的對應(yīng)欄內(nèi)某快餐廳主要制作并出售兒童套餐,一般包括主餐(各類比薩)、飲料和玩具,其餐品種類可能不同,但其制作過程相同。前臺服務(wù)員(Waiter調(diào)度廚師制作套餐。現(xiàn)采用生成器(Builder)模式實現(xiàn)制作過程,得到如圖5-1所示的類圖。圖5-1I類圖【C+代碼】#include#includeusingnamespacestd;classPizzaprivate:stringparts;public:voidsetParts(stringparts)this-parts=parts;stringgetParts()ret

15、urnparts;classPizzaBuilderprotected:Pizza*pizza;public:Pizza*getPizza()retumpizza;voidcreateNewPizza()pizza=newPizza();(1);classHawaiianPizzaBuilder:publicPizzaBuilderpublic:voidbuildParts()pizza-setParts(cross+mild+ham&pineappie);classSpicyPizzaBuider:publicPizzaBuilderpublic:voidbuildParts()pizza-

16、setParts(panbaked+hot+ham&pineapple);ClassWaiterPrivate:PizzaBuilder*pizzaBuilder;public:voidsetPizzaBuilder(PizzaBuilder*pizzaBuilder)設(shè)置構(gòu)建器*/(2)Pizza*getPizza()returnpizzaBuilder-getPizza();voidconstruct()/*構(gòu)建*/pizzaBuilder-createNewPizza();(3);intmain()Waiter*waiter=newWaiter();PizzaBuilder*hawaii

17、anpizzabuilder=newHawaiianPizzaBuilder()(4);(5);coutpizza:getPizza()-getParts()r*bukfParta(6-1類圖【Java代碼】classPizzaprivateStringpartspublicvoidsetParts(Stringparts)this.parts=parts;publicStringtoString()returnthis.parts;abstractclassPizzaBuilderprotectedPizzapizza;publicPizzagetPizza()returnpizza;pub

18、licvoidcreateNewPizza()pizza=newPizza();public(1);classHawaiianPizzaBuilderextendsPizzaBuilderpublicvoidbuildParts()pizza.setParts(cross+mild+ham&pineapp1)eclassSpicyPizzaBuilderextendsPizzaBuilderpublicvoidbuildParts()pizza.setParts(panbaked+hot+pepperoni&salami);classWaiterprivatePizzaBuilderpizza

19、Builder;publicvoidsetPizzaBuilder(PizzaBuilderpizzaBuilder)/*設(shè)置構(gòu)建器*/(2);publicPizzagetPizza()returnpizzaBuilder.getPizza();publicvoidconstruct()/*構(gòu)建*/pizzaBuilder.createNewPizza();(3);ClassFastFoodOrderingpublicstaticviodmainStingargs)Waiterwaiter=newWaiter();PizzaBuilderhawaiian_pizzabuilder=newHaw

20、aiianPizzaBuilder();(4);(5);System.out.println(pizza:+waiter.getPizza();程序的輸出結(jié)果為:Pizza:cross+mild+ham&pineapple試題一答案解析:1:E1供應(yīng)商E2采購部門E3檢驗員E4庫管員E5職員2:D1庫存表D2采購訂單表D3質(zhì)量標(biāo)準(zhǔn)表D4供應(yīng)商表3:P3(驗證裝運部件)-E1(客戶)P4(校驗部件質(zhì)量)-E1(客戶)P3(驗證裝運部件)-P4(校驗部件質(zhì)量)P1(檢查庫存水平)-D1(庫存表)4:父圖中某個加工的輸入輸出數(shù)據(jù)流必須與其子圖的輸入輸出數(shù)據(jù)流在數(shù)量上和內(nèi)容上保持一致,即數(shù)據(jù)不會憑空產(chǎn)

21、生,也不能憑空消失。父圖的一個輸入(或輸出)數(shù)據(jù)流應(yīng)對應(yīng)子圖中幾個輸入(或輸出)數(shù)據(jù)流,而子圖中組成的這些數(shù)據(jù)流的數(shù)據(jù)項全體正好是父圖中的這個數(shù)據(jù)流。試題二答案解析:2 a)業(yè)務(wù)技能b)樓編號c)月租金新增維修關(guān)系,維修工維修公寓,關(guān)系模式為維修情況維修情況(故障編號,員工編號,樓編號,公寓號,維修日期,維修內(nèi)容)試題三答案解析:a):C4C5C7C8C10C11b):C3c):C1C2C6C9C12一、實體類實體類是用于對必須存儲的信息和相關(guān)行為建模的類。實體對象(實體類的實例)用于保存和更新一些現(xiàn)象的有關(guān)信息,例如:事件、人員或者一些現(xiàn)實生活中的對象。實體類通常都是永久性的,它們所具有的屬

22、性和關(guān)系是長期需要的,有時甚至在系統(tǒng)的整個生存期都需要。二、邊界類邊界類是系統(tǒng)內(nèi)部與系統(tǒng)外部的業(yè)務(wù)主角之間進行交互建模的類。邊界類依賴于系統(tǒng)外部的環(huán)境,比如業(yè)務(wù)主角的操作習(xí)慣、外部的條件的限制等。它或者是系統(tǒng)為業(yè)務(wù)主角操作提供的一個GUI或者系統(tǒng)與其他的系統(tǒng)之間進行一個交互的接口,所以當(dāng)外部的GUI變化時,或者是通信協(xié)議有變化時,只需要修改邊界類就可以了,不用再去修改控制類和實體類。業(yè)務(wù)主角通過它來與控制對象交互,實現(xiàn)用例的任務(wù)。邊界類調(diào)用用例內(nèi)的控制類對象,進行相關(guān)的操作。一個系統(tǒng)可能會有多種邊界類:用戶界面類-幫助與系統(tǒng)用戶進行通信的類系統(tǒng)接口類-幫助與其他系統(tǒng)進行通信的類設(shè)備接口類-為用

23、來監(jiān)測外部事件的設(shè)備(如傳感器)提供接口的類三、控制類控制類用于對一個或幾個用例所特有的控制行為進行建模,它描述的用例的業(yè)務(wù)邏輯的實現(xiàn),控制類的設(shè)計與用例實現(xiàn)有著很大的關(guān)系。在有些情況下,一個用例可能對應(yīng)多個控制類對象,或在一個控制類對象中對應(yīng)著對個用例。它們之間沒有固定的對應(yīng)關(guān)系,而是根據(jù)具體情況進行分析判斷,控制類有效將業(yè)務(wù)邏輯獨立于實體數(shù)據(jù)和邊界控制,專注于處理業(yè)務(wù)邏輯,控制類會將特有的操作和實體類分離,者有利于實體類的統(tǒng)一化和提高復(fù)用性。當(dāng)業(yè)務(wù)主角通過邊界類來執(zhí)行用例的時候,產(chǎn)生一個控制類對象,在用例被執(zhí)行完后,控制類對象會被銷毀。控制類的特點:獨立于環(huán)境、和用例的實現(xiàn)關(guān)聯(lián)、使用關(guān)聯(lián)實體類或操作實體類對象、專注于業(yè)務(wù)邏

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論