背包问题~~!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;
} 
 
相关推荐
Wect6 小时前
LeetCode 130. 被围绕的区域:两种解法详解(BFS/DFS)
前端·算法·typescript
NAGNIP18 小时前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
端平入洛1 天前
delete又未完全delete
c++
颜酱1 天前
单调栈:从模板到实战
javascript·后端·算法
CoovallyAIHub1 天前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
强化学习凭什么比监督学习更聪明?RL的“聪明”并非来自算法,而是因为它学会了“挑食”
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
YOLO-IOD深度解析:打破实时增量目标检测的三重知识冲突
深度学习·算法·计算机视觉
NAGNIP2 天前
轻松搞懂全连接神经网络结构!
人工智能·算法·面试