背包问题的递归与非递归求解

对于递归转到非递归问题 ,一般都是 自己构造一个栈。


/*#include<stdio.h>

int knap(int w[],int v,int n){
    if(v == 0) return 1;
    else{
        if(v < 0 || (v>0 && n<1)) return 0;
        else{
            if(knap(w,v-w[n-1],n-1)==1){
                printf("result:n = %d,w[%d] = %d\n",n,n-1,w[n-1]);
                return 1;
            }
            else return knap(w,v,n-1);
        }
    }
}

int main(){
    int w[5] = {1,4,4,5,7};
    int n = 5;
    int v = 10;
    knap(w,v,n);
    return 0;
}*/

#include<stdio.h>
#define MAXSIZE 100
typedef int ElemType;
typedef struct{
    ElemType data[MAXSIZE];
    int top;
}SqStack;
void Init_SqStack(SqStack &S) {S.top = -1;}
int Empty_SqStack(SqStack &S){
    if(S.top == -1) return 1;
    else return 0;
}

void Push_SqStack(SqStack &S,ElemType x){
    if(S.top == MAXSIZE -1) return ;
    else S.data[++S.top] = x;
}
void Pop_SqStack(SqStack &S,ElemType &e){
    if(Empty_SqStack(S)){
        return;
    }
    else{
        e = S.data[S.top];
        S.top --;
    }
}

int knap(int w[],int v,int n){
    SqStack S;
    int j,k;
    Init_SqStack(S);
    k = 0;
    do{
        while(v>0 && k<n){
            if(v-w[k]>=0){
                Push_SqStack(S,k);
                v-=w[k];
            }
            k++;
        }
        if(v == 0){
            printf("\nresult:\n");
            for(j = 0;j<=S.top;j++){
                printf("n=%d,w[%d] = %d\n",S.data[j]+1,S.data[j],w[S.data[j]]);
            }
        }
        Pop_SqStack(S,k);
        v+=w[k];
        k++;
    }while(!Empty_SqStack(S) || k!=n);
}

int main(){
    int w[5] = {1,4,4,5,7};
    int n = 5;
    int v = 10;
    knap(w,v,n);
    return 0;
}





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
#include <iostream.h> #include<iomanip.h> #include<string.h> int min(int w,int c) {int temp; if (w<c) temp=w; else temp=c; return temp; } int max(int w,int c) { int temp; if (w>c) temp=w; else temp=c; return temp; } void knapsack(int v[],int w[],int c,int n,int**m) //求最优值 { int jmax=min(w[n]-1,c); for(int j=0;j<=jmax;j++) m[n][j]=0; for(int jj=w[n];jj<=c;jj++) m[n][jj]=v[n]; for(int i=n-1;i>1;i--){ //递归部分 jmax=min(w[i]-1,c); for(int j=0;j<=jmax;j++) m[i][j]=m[i+1][j]; for(int jj=w[i];jj<=c;jj++) m[i][jj]=max(m[i+1][jj],m[i+1][jj-w[i]]+v[i]); } m[1][c]=m[2][c]; if(c>=w[1]) m[1][c]=max(m[1][c],m[2][c-w[1]]+v[1]); cout<<"最优值:"<<m[1][c]<<endl; for(int l=2;l<=n;l++) for(int j=0;j<=c;j++) { cout<<m[l][j]<<setw(c-1); } cout<<endl; cout<<"*******************************************"<<endl; } int traceback(int **m,int w[],int c,int n,int x[]) //回代,求最优解 { cout<<"得到的一组最优解如下:"<<endl; for(int i=1;i<n;i++) if(m[i][c]==m[i+1][c]) x[i]=0; else {x[i]=1; c-=w[i];} x[n]=(m[n][c])?1:0; for(int y=1;y<=n;y++) { cout<<setw(5)<<x[y]; } return x[n]; } void main() { int n,c; int **m; cout<<"欢迎使用0-1背包问题程序"<<endl; cout<<"请输入物品个数和重量上限:"; cin>>n>>c; int *v=new int[n+1]; cout<<"Pls input the property (v[i]):"<<endl; for(int i=1;i<=n;i++) cin>>v[i]; int *w=new int[n+1]; cout<<"Pls input the weight (w[i]):"<<endl; for(int j=1;j<=n;j++) cin>>w[j]; int *x=new int[n+1]; m=new int*[n+1]; //动态的分配二维数组 for(int p=0;p<n+1;p++) { m[p]=new int[c+1]; } knapsack(v,w,c,n,m); traceback(m,w,c,n,x); }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值