版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
第6章分枝限界法6.1分枝限界法的基本思想
6.2
0-1背包問題
6.3作業(yè)調(diào)度問題
習(xí)題
6.1分枝限界法的基本思想
如果把回溯法看做深度優(yōu)先搜索解空間樹的過程,那么分枝限界法則可看做廣度優(yōu)先或者按照最大價(jià)值(或最小成本)搜索解空間樹的過程。它也是一種系統(tǒng)地搜索問題解的方法。按照從活結(jié)點(diǎn)表中選擇擴(kuò)展結(jié)點(diǎn)的方法,分枝限界法又可細(xì)分為以下兩種:
(1)先進(jìn)先出(FirstInFirstOut,F(xiàn)IFO)分枝限界法(FIFOBB)。
(2)優(yōu)先隊(duì)列(PriorityQueue,PQ)分枝限界法(PQBB)。我們以0-1背包問題為例,討論這兩種分枝限界法的異同。某商店有n個(gè)物品,第i個(gè)物品價(jià)值為vi,容量(或稱權(quán)值)為wi,其中vi和wi為非負(fù)數(shù)。背包的容量為W,W為一非負(fù)數(shù)。目標(biāo)是如何選擇裝入背包的物品,使裝入背包的物品總價(jià)值最大。這個(gè)問題的形式描述如下:
約束條件為
1.先進(jìn)先出狀態(tài)空間樹
對(duì)于0-1背包問題,結(jié)點(diǎn)X處的估值函數(shù) 定義為 ,其中k表示結(jié)點(diǎn)X所在的層。用隊(duì)列作為組織活結(jié)點(diǎn)表的數(shù)據(jù)結(jié)構(gòu),按照結(jié)點(diǎn)進(jìn)入隊(duì)列的先后順序選擇下一個(gè)擴(kuò)展結(jié)點(diǎn),得到0-1背包問題先進(jìn)先出狀態(tài)空間樹,如圖6-1所示。圖6-1先進(jìn)先出狀態(tài)空間樹
2.優(yōu)先隊(duì)列狀態(tài)空間樹
當(dāng)用優(yōu)先隊(duì)列作為組織活結(jié)點(diǎn)表的數(shù)據(jù)結(jié)構(gòu),并按照結(jié)點(diǎn)估值函數(shù)值的大小選擇下一個(gè)擴(kuò)展結(jié)點(diǎn)時(shí),就得到0-1背包問題優(yōu)先隊(duì)列狀態(tài)空間樹,如圖6-2所示。圖6-2優(yōu)先隊(duì)列狀態(tài)空間樹正如在回溯法中所做的那樣,我們可以設(shè)計(jì)一個(gè)限界函數(shù),以減少解空間的大小,加速搜索的速度。這個(gè)限界函數(shù)給出每一個(gè)可行結(jié)點(diǎn)對(duì)應(yīng)子樹可能得到的最小成本(最大價(jià)值)的下界(上界),如果這個(gè)下界(上界)不小于(不大于)當(dāng)前最優(yōu)解的值,則說明這個(gè)結(jié)點(diǎn)對(duì)應(yīng)的子樹中不含問題的最優(yōu)解,因而可以剪掉。此外,我們也可以將限界函數(shù)確定的每個(gè)結(jié)點(diǎn)的下界(上界)值作為優(yōu)先級(jí),并以該優(yōu)先級(jí)的大小作為選擇當(dāng)前E結(jié)點(diǎn)的原則。這種策略有時(shí)可以更快地找到問題的最優(yōu)解。
6.2
0-1背包問題
1.限界
設(shè)T是一棵狀態(tài)空間樹,c(*)是T中結(jié)點(diǎn)的成本函數(shù)。如果X是T中的一個(gè)結(jié)點(diǎn),則c(X)是其根為X的子樹中任一答案結(jié)點(diǎn)的最小成本。這個(gè)c(*)是難于構(gòu)造的,通常使用一個(gè)對(duì)c(*)估值的啟發(fā)式函數(shù)l(*)來代替,這個(gè)啟發(fā)式函數(shù)易于計(jì)算:如果X是一個(gè)答案結(jié)點(diǎn)或一個(gè)葉結(jié)點(diǎn),則c(*)=l(*)。搜索問題狀態(tài)空間樹的各種分枝限界法都是在生成當(dāng)前E結(jié)點(diǎn)的所有子結(jié)點(diǎn)之后再將另一結(jié)點(diǎn)變成E結(jié)點(diǎn)的。假定每個(gè)答案結(jié)點(diǎn)X有一個(gè)與其相聯(lián)系的c(X),并且假定會(huì)找到最小成本的答案結(jié)點(diǎn),利用一個(gè)滿足l(X)≤c(X)的成本估值函數(shù)l(X)則可以給出任一結(jié)點(diǎn)X解的下界。采用下界函數(shù)可以減少搜索的盲目性,此外還可通過設(shè)置最小成本上界使算法進(jìn)一步加速。如果Up是最小成本解的成本上界,則滿足l(X)>Up的所有活結(jié)點(diǎn)都可以被殺死,這是因?yàn)橛蒟到達(dá)的
所有答案結(jié)點(diǎn)都滿足c(X)≥l(X)>Up。在已經(jīng)到達(dá)一個(gè)具有成本Up的答案結(jié)點(diǎn)的情況下,那些滿足l(X)>Up的所有活結(jié)點(diǎn)都可以被殺死。Up的初始值可以用某種啟發(fā)式算法得到,也可以設(shè)置成∞。只要Up的初始值不小于最小成本結(jié)點(diǎn)的成本,上述殺死活結(jié)點(diǎn)的規(guī)則就不會(huì)殺死可以到達(dá)最小成本答案結(jié)點(diǎn)的活結(jié)點(diǎn)。每當(dāng)找到一個(gè)新的答案結(jié)點(diǎn)時(shí),就可以修改Up的值,即如果某個(gè)結(jié)點(diǎn)的上界u(X)<Up,則用該結(jié)點(diǎn)的上界u(X)更新Up。根據(jù)上述思想,我們考慮最小值優(yōu)化問題的分枝限界法。為了找問題的最優(yōu)解,需要將最優(yōu)解的搜索表示成對(duì)狀態(tài)空間樹答案結(jié)點(diǎn)的搜索,可將問題最優(yōu)答案結(jié)點(diǎn)的成本函數(shù)定義為所有結(jié)點(diǎn)成本的最小值。簡單的方法是直接將目標(biāo)函數(shù)作為成本函數(shù)c(*)。在這種定義下,可行解結(jié)點(diǎn)的c(X)就是那個(gè)結(jié)點(diǎn)可行解的目標(biāo)函數(shù)值,不可行結(jié)點(diǎn)的c(X)為+∞,部分解結(jié)點(diǎn)的c(X)是以X為根的子樹中結(jié)點(diǎn)的最小成本。
2.定義結(jié)點(diǎn)的限界函數(shù)
通過構(gòu)造和設(shè)計(jì)結(jié)點(diǎn)處的限界函數(shù),可以減小問題的狀態(tài)搜索空間。為了討論方便起見,我們將最大值優(yōu)化問題轉(zhuǎn)變成最小值優(yōu)化問題。如果用目標(biāo)函數(shù)- 替代目標(biāo)函數(shù) ,就使背包問題從一個(gè)最大值優(yōu)化問題變成最小值優(yōu)化問題。顯然, 取最小即 取最大。重新定義了目標(biāo)函數(shù)之后,背包問題描述如下:(6.1)約束條件為
式(6.1)中各量的意義同6.1節(jié)。UPBOUND(cv,cw,k-1,W)
1 b
cv
2 c
cw
3 for
i
k
to
n
do
4
ifc+w[i]
W
5
then
c
c+w[i]
6 b
b–v[i]
7 return(b)
3.0-1背包問題優(yōu)先隊(duì)列分枝限界法示例
對(duì)于上述構(gòu)造的限界函數(shù)l(X)和u(X),再次考慮6.1節(jié)的0-1背包問題實(shí)例。用優(yōu)先隊(duì)列作為組織活結(jié)點(diǎn)表的數(shù)據(jù)結(jié)構(gòu),并按照結(jié)點(diǎn)l(X)值的大小選擇下一個(gè)擴(kuò)展結(jié)點(diǎn),得到0-1
背包問題優(yōu)先隊(duì)列分枝限界樹,如圖6-3所示。圖6-3
0-1背包問題優(yōu)先隊(duì)列分枝限界樹
4.算法中使用的主要數(shù)據(jù)結(jié)構(gòu)及變量
由此可見,通過限界函數(shù),大大減小了問題的搜索空間,提高了算法的效率。但另一方面,僅從路徑10,7,4,2,1不能確定哪些物品裝入背包,使得-∑vixi=Up,即不能確定裝入背包中物品xi的取值情況。因此,在實(shí)現(xiàn)中,需通過設(shè)置一些變量來記錄xi的取值信息。一種辦法是在每一個(gè)結(jié)點(diǎn)上增設(shè)一個(gè)標(biāo)志域Tag,由答案結(jié)點(diǎn)到根結(jié)點(diǎn)的這些標(biāo)志域給出xi的取值信息。
1)結(jié)點(diǎn)的結(jié)構(gòu)
結(jié)點(diǎn)結(jié)構(gòu)取決于用定長元組表示狀態(tài)空間樹,還是用變長元組表示狀態(tài)空間樹。這里仍然采用定長元組表示?;罱Y(jié)點(diǎn)表中的每一個(gè)結(jié)點(diǎn)都有六個(gè)域的信息,如圖6-4所示。圖6-4結(jié)點(diǎn)的數(shù)據(jù)結(jié)構(gòu)
2)擴(kuò)展給定E結(jié)點(diǎn)的子結(jié)點(diǎn)
利用結(jié)點(diǎn)數(shù)據(jù)結(jié)構(gòu)中的信息,可以確定任一活結(jié)點(diǎn)X的兩個(gè)子結(jié)點(diǎn)。當(dāng)且僅當(dāng)CW(X)≥wLevel(X)時(shí),X的左孩子Y是可行結(jié)點(diǎn),可以生成結(jié)點(diǎn)Y,在這種情況下,有
Parent(Y)=X,Level(Y)=Level(X)+1
CW(Y)=CW(X)–wLevel(X),CV(Y)=CV(X)+vLevel(X)
Tag(Y)=1,UB(Y)=UB(X)
當(dāng)CW(X)<wLevel(X)時(shí),生成X的右孩子Y,在這種情況下,有
Parent(Y)=X,Level(Y)=Level(X)+1
CW(Y)=CW(X),CV(Y)=CV(X),Tag(Y)=0
3)識(shí)別答案結(jié)點(diǎn)
答案結(jié)點(diǎn)的識(shí)別比較容易,當(dāng)且僅當(dāng)Level(X)=n+1時(shí),X是答案結(jié)點(diǎn)。
4)活結(jié)點(diǎn)表的數(shù)據(jù)結(jié)構(gòu)
采用優(yōu)先隊(duì)列作為組織活結(jié)點(diǎn)表的數(shù)據(jù)結(jié)構(gòu)。需要在優(yōu)先隊(duì)列上執(zhí)行三個(gè)操作:判定優(yōu)先隊(duì)列是否為空、向優(yōu)先隊(duì)列中插入結(jié)點(diǎn)(類似于過程INSERT,見4.4節(jié))和從優(yōu)先隊(duì)列中摘取具有最小l(X)值的結(jié)點(diǎn)(類似于過程EXTRACT-MIN,見4.4節(jié))。我們用最小堆實(shí)現(xiàn)優(yōu)先隊(duì)列數(shù)據(jù)結(jié)構(gòu),如果堆中有n個(gè)結(jié)點(diǎn),則判斷優(yōu)先隊(duì)列是否為空的操作可在常數(shù)時(shí)間
O(1)內(nèi)完成,插入操作和摘取操作的運(yùn)行時(shí)間為O(lbn),因?yàn)檫@兩個(gè)操作不會(huì)超過樹的深度O(lbn)。詳細(xì)的分析見4.4節(jié)。
5.0-1背包問題優(yōu)先隊(duì)列分枝限界算法
在過程PQBB中,調(diào)用6個(gè)子過程,分別是LUBOUND、INSERTNODE、PRINT、INIT、GETNODE和EXTRACT-MAX。過程LUBOUND用于計(jì)算-l(X)和-u(X)。INSERTNODE生成一個(gè)6個(gè)數(shù)據(jù)域的結(jié)點(diǎn),并對(duì)各個(gè)域進(jìn)行賦值,最后插入到活結(jié)點(diǎn)表中。算法PRINT輸出問題最優(yōu)解
的值和最優(yōu)解。算法INIT對(duì)可用結(jié)點(diǎn)表和活結(jié)點(diǎn)表初始化。算法GETNODE取一個(gè)可用結(jié)點(diǎn)。算法EXTRACT-MAX從活結(jié)點(diǎn)表中摘取一個(gè)具有最大UB值的結(jié)點(diǎn)作為E結(jié)點(diǎn),用最大堆實(shí)現(xiàn)時(shí)即摘取堆頂結(jié)點(diǎn)。LUBOUND(v,w,cw,cv,
n,k,LBB,UBB)
//cw表示背包可用權(quán)值,cv表示已得價(jià)值,LBB=–u(X),UBB=–l(X)
1 LBB
cv
2 c
cw
3 fori
k
to
n
do
4
ifc<w[i]
5
thenUBB
LBB+c
v[i]/w[i]
6
forj
i+1tondo
7
if
c
w[j]
8
then
c
c–w[i]
9
LBB
LBB+v[j]
10
return
11 c
c–w[i]
12
LBB
LBB+v[i]
13 UBB
LBBINSERTNODE(par,lev,t,cap,valu,ub)
1 GETNODE(Node)//生成一個(gè)新結(jié)點(diǎn)Node
2 Parent(Node)
par
3 Level(Node)
lev
4 Tag(Node)
t
5 CW(Node)
cap
6 CV(Node)
valu
7 ADD(Node) PRINT(Lower,ans,n)
1 print(''valueofoptimalsolutionis'',Lower)
2 forj
n
downto1do
3
ifTag(ans)=1
4
thenprint(j)
5
ans
Parent(ans)
假設(shè)物品已經(jīng)按照每單位權(quán)值非增排序,即v[i]/w[i]≥v[i+1]/w[i+1]。算法LCBB中使用了一個(gè)小的正參數(shù)ε,算法如下:LCBB(v,w,W,n,
)
1 INIT//初始化可用結(jié)點(diǎn)及活結(jié)點(diǎn)表
2 INSERT-NODE(E)//根結(jié)點(diǎn)
3 Parent(E)
0
4 Level(E)
1
5 CW(E)
W
6 CV(E)
0
7 LUBOUND(v,w,W,n,0,1,LBB,UBB)
8 Lower
LBB–
9 UB(E)
UBB
10 do11 i
Level(E)
12 cap
CW(E)
13 valu
CV(E)
14 if(i=n+1)//葉結(jié)點(diǎn)
15
if
valu>Lower
16 thenLower
valu
17
ans
E
18 elseif
cap
w[i]//左孩子可行
19
thenINSERTNODE(E,i+1,1,cap–w[i],valu+v[E],UB[E])20
LUBOUND(v,w,cap,valu,n,i+1,LBB,UBB)//右孩子是否成為活結(jié)點(diǎn)
21
ifUBB>Lower//判斷右孩子是否成為活結(jié)點(diǎn)
22 thenINSERTNODE(E,i+1,0,cap,valu,UBB)
23 Lower
max{Lower,LBB–
}
24
if
不存在活結(jié)點(diǎn)thenbreak//退出do…while
循環(huán)
25
EXTRACT-MAX(E)//下一個(gè)E結(jié)點(diǎn)是UB中最大的結(jié)點(diǎn)
26 while(UB(E)>Lower)
27 PRINT(Lower,ans,n)
6.0-1背包問題先進(jìn)先出分枝限界算法
考慮6.1節(jié)的0-1背包問題實(shí)例,限界函數(shù)l(X)和u(X)的定義如前所述。用先進(jìn)先出隊(duì)列作為組織活結(jié)點(diǎn)表的數(shù)據(jù)結(jié)構(gòu),并按照結(jié)點(diǎn)l(X)值的大小選擇下一個(gè)擴(kuò)展結(jié)點(diǎn),得到0-1背包問題先進(jìn)先出分枝限界樹,如圖6-5所示。圖6-5
0-1FIFO分枝限界樹
0-1背包問題FIFOBB的算法中,結(jié)點(diǎn)的生成和E結(jié)點(diǎn)的選擇是逐層進(jìn)行的。因此,無需為每個(gè)結(jié)點(diǎn)專門設(shè)置一個(gè)Level域,只需要在隊(duì)列中加上一個(gè)符號(hào)“?!?,作為層結(jié)束標(biāo)志。狀態(tài)空間樹中每個(gè)結(jié)點(diǎn)可用五個(gè)域表示,如圖6-6所示。對(duì)LCBB算法做適當(dāng)修改,就可得到0-1背包問題的FIFOBB算法,在此從略。圖6-6
FIFOBB算法中結(jié)點(diǎn)的數(shù)據(jù)結(jié)構(gòu)
6.3作業(yè)調(diào)度問題
1.定義結(jié)點(diǎn)的限界函數(shù)
圖6-7表示變長元組表示的狀態(tài)空間樹,結(jié)點(diǎn)左邊值表示結(jié)點(diǎn)的l(X)值,結(jié)點(diǎn)右邊值表示當(dāng)前最好上界Up值,一旦找到滿足l(X)>Up
的結(jié)點(diǎn),該結(jié)點(diǎn)就被殺死。標(biāo)有“×”的結(jié)點(diǎn)表示該結(jié)點(diǎn)被殺死,其中標(biāo)有“×”的陰影結(jié)點(diǎn)表示由于是
不可行結(jié)點(diǎn)而被殺死,除陰影結(jié)點(diǎn)之外的所有結(jié)點(diǎn)都是答案結(jié)點(diǎn)。結(jié)點(diǎn)9是問題的最優(yōu)解,它是惟一的最小成本答案結(jié)點(diǎn),此時(shí),最優(yōu)解為J={2,3},罰金為16,即最小成本。對(duì)于這棵樹中的結(jié)點(diǎn),定義成本函數(shù)c(*)如下:對(duì)于不可行結(jié)點(diǎn)(陰影結(jié)點(diǎn)),c(X)=+∞;對(duì)于其他結(jié)點(diǎn),c(X)定義為根為X的子樹中結(jié)點(diǎn)的最小罰金。在圖6-7中,c(1)=16,c(2)=18,c(3)=16。圖6-7變長元組對(duì)應(yīng)的狀態(tài)空間樹
2.作業(yè)調(diào)度問題FIFOBB算法示例
我們利用FIFOBB求解作業(yè)調(diào)度問題,假設(shè)利用圖6-7中的變長元組表示法。初始時(shí),設(shè)置最小成本答案結(jié)點(diǎn)的成本上界為
結(jié)點(diǎn)1作為E結(jié)點(diǎn),依次生成結(jié)點(diǎn)2、3、4和5。在結(jié)點(diǎn)2處,有
由于u(2)=38<Up,Up被修改為38。在結(jié)點(diǎn)3處,有
由于u(3)=28<Up,Up被修改為28。在結(jié)點(diǎn)4處,有
由于l(4)=30>Up,結(jié)點(diǎn)4被殺死。
在結(jié)點(diǎn)5處,有
由于l(5)=42>Up,結(jié)點(diǎn)5也被殺死。基于FIFO原則,結(jié)點(diǎn)2成為下一個(gè)E結(jié)點(diǎn),生成它的子結(jié)點(diǎn)6、7和8。在結(jié)點(diǎn)6處,有
由于u(2)=18<Up=28,Up被修改為18。在結(jié)點(diǎn)7處,有
結(jié)點(diǎn)7被殺死。
結(jié)點(diǎn)8是不可行結(jié)點(diǎn),也被殺死。結(jié)點(diǎn)3成為下一個(gè)E結(jié)點(diǎn),生成它的子結(jié)點(diǎn)9和10。在結(jié)點(diǎn)9處,有
由于u(9)=16<Up=18,Up被修改為16。在結(jié)點(diǎn)10處,有
由于l(10)=22>Up,結(jié)點(diǎn)10被殺死。結(jié)點(diǎn)6成為下一個(gè)E結(jié)點(diǎn),生成它的子結(jié)點(diǎn)11和12。結(jié)點(diǎn)11和12都為不可行結(jié)點(diǎn),均被殺死。結(jié)點(diǎn)9成為下一個(gè)E結(jié)點(diǎn),生成它的子結(jié)點(diǎn)13。結(jié)點(diǎn)13為不可行結(jié)點(diǎn),被殺死。因此,結(jié)點(diǎn)9為最小成本答案結(jié)點(diǎn),成本為16,問題的解J={2,3}。
3.作業(yè)調(diào)度問題FIFOBB-JS算法
過程FIFOBB-JS描述了找最小成本答案結(jié)點(diǎn)的作業(yè)調(diào)度問題的算法。過程中調(diào)用了兩個(gè)子過程,它們是INSERTQ(X)和EXTRACTQ(X),分別表示向隊(duì)列插入一個(gè)結(jié)點(diǎn)和從隊(duì)列中刪除一個(gè)結(jié)點(diǎn)。對(duì)于狀態(tài)空間樹中的每個(gè)答案結(jié)點(diǎn)X,cost(X)是結(jié)點(diǎn)X對(duì)應(yīng)的解的成本。在FIFOBB-JS中,假設(shè)不可行結(jié)點(diǎn)的估值l(X)=+∞,可行結(jié)點(diǎn)的估值l(X)≤c(X)≤u(X)。FIFOBB-JS(T,l,u,
,cost)
1 E
T
2 Parent(E)
0
3 ifT
是解結(jié)點(diǎn)
4
thenUp
min{cost(T),u(T)+
}
5
ans
T
6
elseUp
u(T)+
7 ans
0
8 Q
//初始化隊(duì)列為空
9 while(1)do10
forE的每個(gè)子結(jié)點(diǎn)Xdo//對(duì)當(dāng)前E結(jié)點(diǎn)進(jìn)行擴(kuò)展
11
ifl(X)<Up
12 thenINSERTQ(X)
13
Parent(X)
E
14
if
X
是解結(jié)點(diǎn)&cost(X)<Up
15
thenUp
min{cost(X),u(X)+
}
16
ans
X
17
if
u(X)+
<Up
18
thenUp
u(X)+
19
while(1)do
20 ifEmpty(Q)//如果隊(duì)列Q為空
21
thenprint(“l(fā)eastcost=”,Up)
22
while
ans
0do
23
print(ans)
24
ans
Parent(ans)
25
return//返回
26 EXTRACTQ(X)
27 ifl(X)<Up
28
then
exit//殺死l(X)
Up的結(jié)點(diǎn),退出第19行的while循環(huán)體第1~8行進(jìn)行初始化。第10行擴(kuò)展E的每個(gè)子結(jié)點(diǎn)X。第11行,如果l(X)<Up,調(diào)用INSERTQ,將E
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 鴕鳥防病知識(shí)培訓(xùn)課件
- 中國移動(dòng)個(gè)人年終總結(jié)
- 二零二五年度建筑工程砂漿采購合同糾紛處理協(xié)議3篇
- 時(shí)間規(guī)劃管理
- 國家石油天然氣管網(wǎng)集團(tuán)有限公司介紹
- 2025年度辦公租賃合同范本附租賃物業(yè)消防及安全責(zé)任規(guī)定3篇
- 2025版爆破工程承包與風(fēng)險(xiǎn)評(píng)估協(xié)議3篇
- 二零二五年度建筑工程基礎(chǔ)知識(shí)專業(yè)論壇組織與管理合同3篇
- 二零二五年度住房和城鄉(xiāng)建設(shè)局建筑行業(yè)信用體系建設(shè)合同2篇
- 年產(chǎn)1萬套儲(chǔ)能柜機(jī)箱機(jī)柜新建項(xiàng)目可行性研究報(bào)告寫作模板-備案審批
- 八年級(jí)上冊(cè)科學(xué)(浙教版)復(fù)習(xí)提綱
- 商務(wù)溝通第二版第4章書面溝通
- 《動(dòng)物遺傳育種學(xué)》動(dòng)物醫(yī)學(xué)全套教學(xué)課件
- 基金會(huì)項(xiàng)目基金捐贈(zèng)立項(xiàng)表
- OCT青光眼及視野報(bào)告
- 人音版小學(xué)音樂四年級(jí)下冊(cè)課程綱要
- 初中語文人教七年級(jí)上冊(cè)朝花夕拾學(xué)生導(dǎo)讀單
- 山西鄉(xiāng)寧焦煤集團(tuán)臺(tái)頭煤焦公司礦井兼并重組整合項(xiàng)目初步設(shè)計(jì)安全專篇
- 弱電工程自檢報(bào)告
- DB33∕T 628.1-2021 交通建設(shè)工程工程量清單計(jì)價(jià)規(guī)范 第1部分:公路工程
- (完整版)八年級(jí)上綜合性學(xué)習(xí)-我們的互聯(lián)網(wǎng)時(shí)代-練習(xí)卷(含答案)
評(píng)論
0/150
提交評(píng)論