news 2026/6/10 15:35:22

背包问题~~!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/10 0:25:16

如果只读一本“数学史”入门书,那必须是这一本!

在传统的大学本科课程中, 微积分是进入高等数学的入口。它已经成为工程师、物理学家、化学家、经济学家等各种专业人士的不可或缺的工具。微积分显然是17世纪数学的最高成就, 很多人认为它是整个数学发展史上的最高成就。20世纪最具影响力的数学家之一约翰 • 冯诺依曼&#xf…

作者头像 李华
网站建设 2026/6/9 19:58:39

ComfyUI与Docker Desktop集成:简化容器化流程

ComfyUI 与 Docker Desktop 集成&#xff1a;构建可复用、可交付的 AI 工作流 在生成式 AI 暴发式增长的今天&#xff0c;我们早已不再满足于“跑通一个模型”或“出一张图”。越来越多的开发者、设计师和工程团队面临更深层的问题&#xff1a;如何让复杂的图像生成流程变得可…

作者头像 李华
网站建设 2026/6/10 11:35:14

掌握es-client:Elasticsearch可视化管理终极指南

掌握es-client&#xff1a;Elasticsearch可视化管理终极指南 【免费下载链接】es-client elasticsearch客户端&#xff0c;issue请前往码云&#xff1a;https://gitee.com/qiaoshengda/es-client 项目地址: https://gitcode.com/gh_mirrors/es/es-client 想要高效管理El…

作者头像 李华
网站建设 2026/6/10 15:09:41

完整OpenModScan指南:3步掌握工业通讯调试核心技能

OpenModScan作为一款专业的Modbus主站测试工具&#xff0c;为工业自动化工程师和现场调试人员提供了全面的Modbus协议验证解决方案。该工具支持Modbus-TCP和Modbus-RTU双协议&#xff0c;能够有效提升设备调试效率和通讯可靠性。 【免费下载链接】OpenModScan Open ModScan is …

作者头像 李华
网站建设 2026/6/10 11:33:55

如何通过GitHub镜像快速部署HunyuanVideo-Foley实现视频自动配乐

如何通过 GitHub 镜像快速部署 HunyuanVideo-Foley 实现视频自动配乐 在短视频日活突破十亿、内容生产节奏以“分钟”为单位的今天&#xff0c;音效设计却依然是许多团队卡脖子的环节。一个5分钟的创意短片&#xff0c;可能拍摄只要两小时&#xff0c;剪辑一晚上搞定&#xff0…

作者头像 李华