背包问题~~!C++

5 10 //5代表5件物品 10代表 取这5件物品种 哪几样 可以加起来为10

1 2 3 4 5

//第1件物品重量1

//第2件物品重量2

//第3件物品重量3

//第4件物品重量4

//第5件物品重量5

现在我们想,我们有一个布袋,初始状态里面是空的,意味着哪几方面信息?

第一, 重量为0

第二, 物品个数为0

第三, 总重量不等于10

以上状态我们用0来表示

接下来我们分析我们对第一个物品可以做的事,就是把他放进布袋,或不放进布袋

那们结合前面的0状态,再加上第一个物品的两个状态就可以看到以下情况:

复制代码
                            0
                        0        1                  0代表不取    1代表取

如果这看明白了,在对一个物品处理之后,就是处理第二个物品

是不是:

复制代码
                      0

0 1

0 1 0 1

同样第三个,第四个也是这原理

复制代码
                        0

0 1

0 1 0 1

0 1 0 1 0 1 0 1

...

如果以上能理解了,就应当有递归的感觉了

题目要求:找到一组解即可。说明会有很多情况其实是可以满足要求的:

比如上面的案例: 1234为10 145为10 235为10

接下来用代码写函数

cpp 复制代码
5  10    //5代表5件物品     10代表 取这5件物品种 哪几样 可以加起来为10
1	2  3  4  5    


//第1件物品重量1
//第2件物品重量2
//第3件物品重量3
//第4件物品重量4
//第5件物品重量5


现在我们想,我们有一个布袋,初始状态里面是空的,意味着哪几方面信息?
第一,	重量为0
第二,	物品个数为0
第三,	总重量不等于10

以上状态我们用0来表示

接下来我们分析我们对第一个物品可以做的事,就是把他放进布袋,或不放进布袋
那们结合前面的0状态,再加上第一个物品的两个状态就可以看到以下情况:


                                0
                            0        1                  0代表不取    1代表取

如果这看明白了,在对一个物品处理之后,就是处理第二个物品


是不是:

                          0
0	  1
                  0     1   0   1
同样第三个,第四个也是这原理


                            0
0	    1
                  0     1      0    1
0   1  0  1   0  1  0  1
                         .....


如果以上能理解了,就应当有递归的感觉了     
题目要求:找到一组解即可。说明会有很多情况其实是可以满足要求的:
比如上面的案例:  1234为10          145为10    235为10
接下来用代码写函数
#include<iostream>
using namespace std;
typedef struct {
    int index;
    int value;
}Data;

int a[10000],s,n;
Data data[10000];
int size; 
bool check(int Sumweigth,int cnt){  
    if(cnt==-1) return Sumweigth==s;//如没有可选,返回布袋与要求的是否一致
    else if(check(Sumweigth+a[cnt],cnt-1)){//当前位置放入布袋继续分析
        data[size].index=cnt;
        data[size].value=a[cnt];
        size++;
        return true; 
    }else if(check(Sumweigth,cnt-1)){//当前位置没进包里,继续分析 
        return true;
    }
    return false ;
} 
void print(){    
    for(int i=0;i<size;i++)
        cout<<"number:"<<data[i].index+1<<" weight:"<<data[i].value<<endl;//index+1 因为下标是从0开始的  
}
void solve(){
    cin>>n>>s;
    for(int i=0;i<n;i++)    
        cin>>a[i];
    
    if(check(0,n-1))    
        print();    
    else    
        cout<<"not found"<<endl;    
}
int main(){
    solve();    
    return 0;
} 
 
相关推荐
z落落15 小时前
C#WinForm控件实战:Panel与单选框动态创建
开发语言·c#
ptc学习者15 小时前
python 中描述符@property property 大概的样子
开发语言·python
zmzb010315 小时前
Python课后习题训练记录Day129
开发语言·python
洛水水16 小时前
【力扣100题】81.寻找两个正序数组的中位数
数据结构·算法·leetcode
张忠琳16 小时前
【Go 1.26.4】Golang Map 深度解析
开发语言·后端·golang
Vertira16 小时前
如何对QT开发的软件进行打包[已解决]
开发语言·qt
AI人工智能+电脑小能手16 小时前
【大白话说Java面试题 第110题】【并发篇】第10题:CAS 存在哪些问题?
java·开发语言·面试
石一峰69916 小时前
C 语言函数设计模式实战经验
c语言·开发语言·设计模式
sitellla16 小时前
Pydub:用 Python 处理音频,不写废话
开发语言·python·其他·音视频
happymaker062616 小时前
LeetCodeHot100——155.最小栈
算法