news 2026/6/3 4:07:12

背包问题~~!C++

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
背包问题~~!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
接下来用代码写函数

510//5代表5件物品 10代表 取这5件物品种 哪几样 可以加起来为1012345//第1件物品重量1//第2件物品重量2//第3件物品重量3//第4件物品重量4//第5件物品重量5现在我们想,我们有一个布袋,初始状态里面是空的,意味着哪几方面信息? 第一, 重量为0第二, 物品个数为0第三, 总重量不等于10以上状态我们用0来表示 接下来我们分析我们对第一个物品可以做的事,就是把他放进布袋,或不放进布袋 那们结合前面的0状态,再加上第一个物品的两个状态就可以看到以下情况:0010代表不取1代表取 如果这看明白了,在对一个物品处理之后,就是处理第二个物品 是不是:0010101同样第三个,第四个也是这原理001010101010101.....如果以上能理解了,就应当有递归的感觉了 题目要求:找到一组解即可。说明会有很多情况其实是可以满足要求的: 比如上面的案例:1234101451023510接下来用代码写函数#include<iostream>usingnamespacestd;typedefstruct{intindex;intvalue;}Data;inta[10000],s,n;Data data[10000];intsize;boolcheck(intSumweigth,intcnt){if(cnt==-1)returnSumweigth==s;//如没有可选,返回布袋与要求的是否一致elseif(check(Sumweigth+a[cnt],cnt-1)){//当前位置放入布袋继续分析data[size].index=cnt;data[size].value=a[cnt];size++;returntrue;}elseif(check(Sumweigth,cnt-1)){//当前位置没进包里,继续分析returntrue;}returnfalse;}voidprint(){for(inti=0;i<size;i++)cout<<"number:"<<data[i].index+1<<" weight:"<<data[i].value<<endl;//index+1 因为下标是从0开始的}voidsolve(){cin>>n>>s;for(inti=0;i<n;i++)cin>>a[i];if(check(0,n-1))print();elsecout<<"not found"<<endl;}intmain(){solve();return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/3 1:47:19

Java应用性能调优实战:async-profiler深度优化指南

Java应用性能调优实战&#xff1a;async-profiler深度优化指南 【免费下载链接】async-profiler Sampling CPU and HEAP profiler for Java featuring AsyncGetCallTrace perf_events 项目地址: https://gitcode.com/GitHub_Trending/as/async-profiler 在现代Java应用…

作者头像 李华
网站建设 2026/6/2 6:28:59

专业级RPA自动化工具taskt完全指南:零代码实现高效工作流

专业级RPA自动化工具taskt完全指南&#xff1a;零代码实现高效工作流 【免费下载链接】taskt taskt (pronounced tasked and formely sharpRPA) is free and open-source robotic process automation (rpa) built in C# powered by the .NET Framework 项目地址: https://git…

作者头像 李华
网站建设 2026/6/2 10:47:01

MobaXterm连接远程Kotaemon服务:Windows下调试智能体全流程

MobaXterm连接远程Kotaemon服务&#xff1a;Windows下调试智能体全流程 在企业级AI应用开发中&#xff0c;一个常见的挑战是&#xff1a;如何让团队中的Windows开发者高效参与部署在Linux服务器上的智能体系统调试&#xff1f;尤其是在构建基于大语言模型&#xff08;LLM&#…

作者头像 李华
网站建设 2026/5/29 20:19:08

FaceFusion支持Windows子系统Linux(WSL)吗?实操验证结果

FaceFusion 支持 WSL 吗&#xff1f;实测告诉你答案 在一台 Windows 笔记本上跑着 Adobe Premiere 剪视频&#xff0c;同时想用 AI 工具把朋友的脸“无缝”换进电影片段里——这种跨生态协作的场景&#xff0c;正变得越来越常见。而 FaceFusion 作为当前开源社区中质量较高、功…

作者头像 李华
网站建设 2026/6/2 8:55:00

Unitree RL GYM完整指南:从零开始掌握机器人强化学习实战

Unitree RL GYM完整指南&#xff1a;从零开始掌握机器人强化学习实战 【免费下载链接】unitree_rl_gym 项目地址: https://gitcode.com/GitHub_Trending/un/unitree_rl_gym Unitree RL GYM是一个专门为宇树机器人设计的强化学习框架&#xff0c;支持G1、H1、H1_2、Go2等…

作者头像 李华