装箱问题

简介: 装箱问题
/*
 *   装箱问题 
 *   算法:贪婪 
 *   coder:qpz
 *   time:2014-11-23 
 */
#include <stdlib.h> 
#include <iostream>
using namespace std;
#define MAX  20
/*
第一步:创建物品字典 
*/ 
typedef struct {
 int gno;//编号
 int ver;//占用空间 
}Gnode;
Gnode *bh(int n); 
void prinGnode(Gnode *a,int n);
/*
 第二步:创建箱子 
 */
 //1.箱子里所装的物品 
typedef struct gnode{
 int gno;//编号
    struct gnode *gnext;//指向物品 
}GGnode; 
//2.箱子
typedef struct box{
 int ver;//箱子体积 
 GGnode *gnext;//指向箱中物品 
 struct box *bnext;//指向下一个箱子 
}Box; 
//打开新箱子 
Box *OpenBox(void);
 /*
  第三步:装箱  
  贪心算法 
 */ 
 Gnode *SortGno(Gnode *a,int n);//排序 
  GGnode *Put(int gno);// 物品放入箱子 
 Box *PackingBox(Gnode *a,int n);//处理过程 
 void prinBox(Box *a,Gnode *dic);//输出箱子信息 
 /*
 free
 */
void takeaway(GGnode *);
void closebox(Box *);
int main(void)
{
 Gnode *a,*b;
 Box *box;
 int n=0;
 cout<<"请输入物品个数:";
 cin>>n;
 if(n){
 a=bh(n); 
 cout<<"排序前"; 
 prinGnode(a,n);
 b=SortGno(a,n);
 cout<<"排序后";
 prinGnode(b,n);
 box=PackingBox(b,n);
     prinBox(box,a);
    closebox(box);
   free (a);
   free (b);
 }else{
 cout<<"没有物品,不用打开箱子"<<endl;
 }
 return 0;
}
//创建物品字典 
Gnode *bh(int n) 
{
 Gnode *a=(Gnode *)malloc(n*sizeof(Gnode));
 for(int i=0;i<n;i++){
 a[i].gno=i+1; 
 cout<<"请输入第"<<a[i].gno<<"个物品的体积"; 
 cin>>a[i].ver;
 } /*end for*/
 cout<<"物品数据库创建成功!!!"<<endl;
 cout<<endl; 
 return a;
} 
//输出物品字典 
void prinGnode(Gnode *a,int n)
{
 cout<<"物品表输出:"<<endl; 
 for(int i=0;i<n;i++){
 cout<<"编号:"<< a[i].gno<<","<<"体积:"<<a[i].ver<<endl;
 }/*end for*/
 cout<<endl;
} 
//排序
 Gnode *SortGno(Gnode *a,int n)
 {
   Gnode *b=(Gnode *)malloc(n*sizeof(Gnode));
   Gnode t;
   for(int i = 0;i < n; i++){
         b[i]=a[i];
   }/*end for*/
    for(int i=0;i<n;i++){
     int max;
     for(int j=max=i;j<n;j++){
     if(b[j].ver>b[max].ver){
     max=j;
     }/*end if*/
     }/*end for2*/
         t=b[i];
     b[i]=b[max];
     b[max]=t;
    }/*end for1*/
   return b;
 } 
//打开新箱子
Box *OpenBox(void)
{
 Box *head;
 head=(Box *)malloc(sizeof(Box));
   head->ver=MAX;
   head->gnext=NULL;
 head->bnext=NULL; 
  return head;
} 
//放入物品
GGnode *Put(int gno)
{ 
     GGnode *gp=(GGnode *)malloc(sizeof(GGnode));
   gp->gno=gno; 
   gp->gnext=NULL;
   return gp;
} 
//装箱 
Box *PackingBox(Gnode *a,int n)
 {
   Box *head,*p,*qb;
   GGnode *gp,*qg;
    head=p=OpenBox();
    for(int i = 0;i < n; i++){
      //是否超过箱子最大容量 是 箱子装不下  输出编号 continue 
      if(a[i].ver > MAX){
       cout<<"编号为"<<a[i].gno<<"的物品体积过大"<<endl;
       continue; 
      }/*end if*/
        qb=p;
     //判断已开箱子可否存入
 while(p&&(a[i].ver > p->ver)){
 qb=p;
                p=p->bnext;  
 } //while
 //没有已开箱子可以装下物品
           if(!p){
                //1.开新箱子
                qb->bnext=p=OpenBox();
           } /*end if*/
                //装箱   
                //1.修改箱子容量 
      p->ver-=a[i].ver;
       //2.放入物品
             for(qg=gp=p->gnext;gp;qg=gp,gp=gp->gnext);
            if(!qg)
     p->gnext=Put(a[i].gno);
     else
     qg->gnext=Put(a[i].gno);
 }/*end for 遍历物品*/
 if(head->ver == MAX){
 head=NULL;
 }
   return head;//箱子头结点地址;
 }
 //输出箱子信息 
 void prinBox(Box *a,Gnode *dic)
 {
   int cnt=0; 
   for(Box *p=a;p;p=p->bnext){
   cout<<"箱子编号:"<<++cnt<<" 箱子剩余空间为:"<<p->ver<<endl;
   if(p->gnext){
   cout<<"箱子中物品有:"<<endl;
   for(GGnode *gp=p->gnext;gp;gp=gp->gnext){
   cout<<"物品编号"<<gp->gno<<" 物品体积:"<<dic[gp->gno-1].ver<<endl;
   }/*end for in*/
   }else{
   cout<<"箱子中没有物品"<<endl; 
   } 
   cout<<endl;
   }/*end for out*/
   cout<<"共打开"<<cnt<<"个箱子"<<endl; 
 }
 void takeaway(GGnode *a)
 {
   GGnode *q;
   for(q=a;a;q=a){
   a=a->gnext;
   free(q);
   }/*end for*/
 }
void closebox(Box *a)
{
 Box *q;
 for(q=a;a;q=a){
 a=a->bnext;
  takeaway(q->gnext);
  free(q);
 }/*end for*/
}
相关文章
|
7月前
|
算法 Python 容器
基于最低水平面的三维装箱问题的启发式算法
基于最低水平面的三维装箱问题的启发式算法
92 0
|
8月前
装箱问题(背包问题)
装箱问题(背包问题)
75 0
|
机器学习/深度学习 传感器 算法
【装箱问题】基于遗传算法求解三维装箱问题附matlab代码
【装箱问题】基于遗传算法求解三维装箱问题附matlab代码
|
机器学习/深度学习
深度之眼(三)——矩阵的行列式
深度之眼(三)——矩阵的行列式
248 0
深度之眼(三)——矩阵的行列式
[物理学与PDEs]第2章第1节 理想流体力学方程组 1.4 一维理想流体力学方程组
1.  一维理想流体力学方程组 $$\beex \bea \cfrac{\p\rho}{\p t}+\cfrac{\p}{\p x}(\rho u)&=0,\\ \cfrac{\p}{\p t}(\rho u) +\cfrac{\p}{\p x}(\rho u^2+p)&=\rho F,\\ \cf...
818 0
|
算法 C++
装箱问题
c++天梯赛算法题
[物理学与PDEs]第4章第3节 一维反应流体力学方程组 3.1 一维反应流体力学方程组
1、 一维粘性热传导反应流体力学方程组 $$\beex \bea \cfrac{\p\rho}{\p t}&+\cfrac{\p}{\p x}(\rho u)=0,\\ \cfrac{\p}{\p t}(\rho u) &+\cfrac{\p}{\p x}\sez{ \rho u^2+p-\sex{...
771 0
|
资源调度
[物理学与PDEs]第3章第5节 一维磁流体力学方程组 5.1 一维磁流体力学方程组
1.  当磁流体力学方程组中的量只依赖于 $t$ 及一个空间变量时, 该方程组称为一维的.     2.  一维磁流体力学方程组 $$\beex \bea \cfrac{\p H_2}{\p t}& +u_1\cfrac{\p H_2}{\p x} +H_2\cfrac{\p u_1}{\p ...
724 0

热门文章

最新文章