贪心法 装箱算法 c++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87 |
//参考书上的算法 #include <iostream> #define N 12 #define V 100 using
namespace
std; typedef
struct
box{ int
id; int
boxsize; struct
box* next; }BOX; void
initboxlist(BOX ** H) { *H=(BOX*) malloc ( sizeof (BOX)); (*H)->id=0; (*H)->boxsize=0; (*H)->next=NULL; } BOX* findbox(BOX* H, int
vl, int
v) { BOX* p=H; while (p != NULL) { if (p->boxsize+vl<=v) break ; p=p->next; } return
p; } void
addlisttail(BOX* H,BOX* p) { BOX* q=H; BOX* tmp=H->next; while (tmp!=NULL) { q=tmp; tmp=tmp->next; } q->next=p; } void
printlist(BOX* H) { BOX* p=H; while (p!=NULL) { cout<<p->id+1<< " " <<p->boxsize<<endl; p=p->next; } } void
addbox( int
vol[], int
v) { BOX* H=NULL; int
boxcount=0; initboxlist(&H); for ( int
i=0;i<N;i++) { BOX *p=findbox(H,vol[i],v); if (p==NULL) { BOX *t=(BOX*) malloc ( sizeof (BOX)); boxcount++; t->id=boxcount; t->boxsize=vol[i]; t->next=NULL; addlisttail(H,t); } else p->boxsize+=vol[i]; } printlist(H); } int
main() { int
vol[]={60, 45, 35, 20, 20, 20,55,87,65,76,67,100}; addbox(vol,V); } |
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。