背包问题~~!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;
} 
 
相关推荐
代码游侠2 分钟前
学习笔记——HC-SR04 超声波测距传感器
开发语言·笔记·嵌入式硬件·学习
AI科技星13 分钟前
光速飞行器动力学方程的第一性原理推导、验证与范式革命
数据结构·人工智能·线性代数·算法·机器学习·概率论
superman超哥14 分钟前
Context与任务上下文传递:Rust异步编程的信息高速公路
开发语言·rust·编程语言·context与任务上下文传递·rust异步编程
橘颂TA15 分钟前
【剑斩OFFER】算法的暴力美学——leetCode 946 题:验证栈序列
c++·算法·leetcode·职场和发展·结构与算法
步达硬件16 分钟前
【Matlab】批量自定义图像处理
开发语言·matlab
闻缺陷则喜何志丹17 分钟前
【状态机动态规划】3686. 稳定子序列的数量|1969
c++·算法·动态规划·力扣·状态机动态规划
军军君0117 分钟前
Three.js基础功能学习七:加载器与管理器
开发语言·前端·javascript·学习·3d·threejs·三维
liulilittle19 分钟前
OPENPPP2 网络驱动模式
开发语言·网络·c++·网络协议·信息与通信·通信
mjhcsp22 分钟前
C++ AC 自动机:原理、实现与应用全解析
java·开发语言·c++·ac 自动机
huihuihuanhuan.xin24 分钟前
后端八股之java并发编程
java·开发语言