軟件設(shè)計師案例分析當(dāng)天每日一練試題地址:m.xiexiliangjiufa.com/exam/ExamDayAL.aspx?t1=4
往期軟件設(shè)計師每日一練試題匯總:m.xiexiliangjiufa.com/class/27/e4_1.html
軟件設(shè)計師案例分析每日一練試題(2024/12/18)在線測試:m.xiexiliangjiufa.com/exam/ExamDayAL.aspx?t1=4&day=2024/12/18
點(diǎn)擊查看:更多軟件設(shè)計師習(xí)題與指導(dǎo)
軟件設(shè)計師案例分析每日一練試題內(nèi)容(2024/12/18)
閱讀下列說明和C代碼,將應(yīng)填入
(n) 處的字句寫在答題紙的對應(yīng)欄內(nèi)。
【說明】
設(shè)某一機(jī)器由n個部件組成,每一個部件都可以從m個不同的供應(yīng)商處購得。供應(yīng)商j供應(yīng)的部件i具有重量wij和價格cij。設(shè)計一個算法,求解總價格不超過上限cc的最小重量的機(jī)器組成。
采用回溯法來求解該問題:
首先定義解空間。解空間由長度為n的向量組成,其中每個分量取值來自集合{1,2,…,m},將解空間用樹形結(jié)構(gòu)表示。
接著從根結(jié)點(diǎn)開始,以深度優(yōu)先的方式搜索整個解空間。從根結(jié)點(diǎn)開始,根結(jié)點(diǎn)成為活結(jié)點(diǎn),同時也成為當(dāng)前的擴(kuò)展結(jié)點(diǎn)。向縱深方向考慮第一個部件從第一個供應(yīng)商處購買,得到一個新結(jié)點(diǎn)。判斷當(dāng)前的機(jī)器價格(c11)是否超過上限(cc),重量(w11)是否比當(dāng)前已知的解(最小重量)大,若是,應(yīng)回溯至最近的一個活結(jié)點(diǎn);若否,則該新結(jié)點(diǎn)成為活結(jié)點(diǎn),同時也成為當(dāng)前的擴(kuò)展結(jié)點(diǎn),根結(jié)點(diǎn)不再是擴(kuò)展結(jié)點(diǎn)。繼續(xù)向縱深方向考慮第二個部件從第一個供應(yīng)商處購買,得到一個新結(jié)點(diǎn)。同樣判斷當(dāng)前的機(jī)器價格(c11+c21)是否超過上限(cc),重量(w11+w21)是否比當(dāng)前已知的解(最小重量)大。若是,應(yīng)回溯至最近的一個活結(jié)點(diǎn);若否,則該新結(jié)點(diǎn)成為活結(jié)點(diǎn),同時也成為當(dāng)前的擴(kuò)展結(jié)點(diǎn),原來的結(jié)點(diǎn)不再是擴(kuò)展結(jié)點(diǎn)。以這種方式遞歸地在解空間中搜索,直到找到所要求的解或者解空間中已無活結(jié)點(diǎn)為止。
【C代碼】
下面是該算法的C語言實現(xiàn)。
(1)變量說明
n:機(jī)器的部件數(shù)
m:供應(yīng)商數(shù)
cc:價格上限
w[][]:二維數(shù)組,w[i][j]表示第j個供應(yīng)商供應(yīng)的第i個部件的重量
c[][]:二維數(shù)組,c[i][j]表示第j個供應(yīng)商供應(yīng)的第i個部件的價格
bestW:滿足價格上限約束條件的最小機(jī)器重量
bestC:最小重量機(jī)器的價格
bestX[]:最優(yōu)解,一維數(shù)組,bestX[i]表示第i個部件來自哪個供應(yīng)商
cw:搜索過程中機(jī)器的重量
cp:搜索過程中機(jī)器的價格
x[]:搜索過程中產(chǎn)生的解,x[i]表示第i個部件來自哪個供應(yīng)商
i:當(dāng)前考慮的部件,從0到n - 1
j:循環(huán)變量
(2)函數(shù)backtrack
int n = 3;
int m = 3;
int cc = 4;
int w[3][3] = {{1,2,3},{3,2,1},{2,2,2}};
int c[3][3] = {{1,2,3},{3,2,1},{2,2,2}};
int bestW = 8;
int bestC = 0;
int bestX[3] = {0,0,0};
int cw = 0;
int cp = 0;
int x[3] = {0,0,0};
int backtrack(int i){
int j = 0;
int found = 0;
if(i > n - 1){ /*得到問題解*/
bestW = cw;
bestC = cp;
for(j = 0; j < n; j++){
(1) ;
}
return 1;
}
if(cp <= cc){ /*有解*/
found = 1;
}
for(j = 0; (2) ; j++){
/*第i個部件從第j個供應(yīng)商購買*/
(3) ;
cw = cw + w[i][j];
cp = cp + c[i][j];
if(cp <= cc && (4) ){ /*深度搜索,擴(kuò)展當(dāng)前結(jié)點(diǎn)*/
if(backtrack(i + 1)){ found = 1; }
}
/*回溯*/
cw = cw - w[i][j];
(5) ;
}
return found;
}
信管網(wǎng)試題答案與解析:m.xiexiliangjiufa.com/exam/ExamDayAL.aspx?t1=4&day=2024/12/18
信管網(wǎng)考友試題答案分享:
信管網(wǎng)試題答案與解析:
m.xiexiliangjiufa.com/exam/ExamDayAL.aspx?t1=4&day=2024/12/18