背包问题:小偷偷东西问题

题目描述

小偷来到了一个神秘的王宫,突然眼前一亮,发现5个宝贝,每个宝贝的价值都不一样,且重量也不一样,但是小偷的背包携带重量有限,所以他不得不在宝贝中做出选择,才能使偷到的财富最大,请你帮助小偷计算一下。

输入描述:

宝贝价值:6,3,5,4,6
宝贝重量:2,2,6,5,4
小偷背包容量:10

输出描述:

偷到宝贝的总价值:15

示例1

输入

6,3,5,4,6

2,2,6,5,4

10

输出

15

#华为#
全部评论
#include <stdio.h> #define BIT(n) (1<<n) int main() {     int v[5];//价值   int h[5];//重量     int c=0;//最大容量     unsigned char bit=31;//二进制11111 分别代表5个宝贝 ,选中为1,未选中为0 共有2^5种 可能性     int maxv=0;//偷到宝贝的总价值     scanf("%d,%d,%d,%d,%d",&v[0],&v[1],&v[2],&v[3],&v[4]);     scanf("%d,%d,%d,%d,%d",&h[0],&h[1],&h[2],&h[3],&h[4]);     scanf("%d",&c);     //循环32次     for(int i=0;i<=bit;i++)     {//判断选中宝贝重量之和是否小于最大容量      if(h[0]*(i&BIT(0))+h[1]*((i&BIT(1))>>1)+h[2]*((i&BIT(2))>>2)+h[3]*\   ((i&BIT(3))>>3)+h[4]*((i&BIT(4))>>4)<=c)      {   //选中宝贝价值是否大于之前的总价值          if( v[0]*(i&BIT(0))+v[1]*((i&BIT(1))>>1)+v[2]*((i&BIT(2))>>2)+v[3]*\ ((i&BIT(3))>>3)+v[4]*((i&BIT(4))>>4)>maxv)          maxv=v[0]*(i&BIT(0))+v[1]*((i&BIT(1))>>1)+v[2]*((i&BIT(2))>>2)+v[3]*\ ((i&BIT(3))>>3)+v[4]*((i&BIT(4))>>4);      }     }                 printf("\n%d\n",maxv);     return 0; } //自己用C语言写的,格式有点乱,凑合着看吧,命令行输入的逗号是英文的逗号,别弄错了 //"\"是我为了看着简洁加上的,不能运行的话删掉就行了
2 回复 分享
发布于 2018-08-08 22:21
也抽到考这题目了,可惜的是当时有人找,点保存,保存不了,就误点了提交,无法再考了,造成机考失败。 我觉得思路如下可行,并且简单。 1、既然是拿最大价值,就把价值数组从大到小排序,同时要把价值对应的重量也要对应上。排序后对应的如图 2、按价值循环加,加的同时判断对应的重量是否大于10,如果不是就继续加 3、最终算出最大价值和对应的重量
1 回复 分享
发布于 2020-02-18 21:03
昨晚的机试题,不太懂动态规划,第一反应可以算价值/重量的性价比然后降序排序,再循环,判断后输出满足容量的最大价值;第二反应是只有5个宝贝,直接穷举所有可能的选择,循环判断满足容量的最大价值;用了第二种,但可能因为是读输入的没读对的问题(输入是三行,每个值之间逗号隔开),没有通过,有点难受。
点赞 回复 分享
发布于 2019-07-29 12:15
不错不错
点赞 回复 分享
发布于 2019-02-15 17:04
01背包
点赞 回复 分享
发布于 2018-08-08 23:32
case通过率60%,实在想不出还有什么情况……
点赞 回复 分享
发布于 2018-08-08 21:30
有个问题,用c++如何把逗号分隔的数据读成数组?
点赞 回复 分享
发布于 2018-08-08 21:27
今晚华为笔试?
点赞 回复 分享
发布于 2018-08-08 21:26
为啥我的输入不是三行!
点赞 回复 分享
发布于 2018-08-08 21:19

相关推荐

想干测开的tomca...:让我来压力你!!!: 这份简历看着“技术词堆得满”,实则是“虚胖没干货”,槽点一抓一大把: 1. **项目描述是“技术名词报菜名”,没半分自己的实际价值** 不管是IntelliDoc还是人人探店,全是堆Redis、Elasticsearch、RAG这些时髦词,但你到底干了啥?“基于Redis Bitmap管理分片”是你写了核心逻辑还是只调用了API?“QPS提升至1500”是你独立压测优化的,还是团队成果你蹭着写?全程没“我负责XX模块”“解决了XX具体问题”,纯把技术文档里的术语扒下来凑字数,看着像“知道名词但没实际动手”的实习生抄的。 2. **短项目塞满超纲技术点,可信度直接***** IntelliDoc就干了5个月,又是RAG又是大模型流式响应又是RBAC权限,这堆活儿正经团队分工干都得小半年,你一个后端开发5个月能吃透这么多?明显是把能想到的技术全往里面塞,生怕别人知道你实际只做了个文件上传——这种“技术堆砌式造假”,面试官一眼就能看出水分。 3. **技能栏是“模糊词混子集合”,没半点硬核度** “熟悉HashMap底层”“了解JVM内存模型”——“熟悉”是能手写扩容逻辑?“了解”是能排查GC问题?全是模棱两可的词,既没对应项目里的实践,也没体现深度,等于白写;项目里用了Elasticsearch的KNN检索,技能栏里提都没提具体掌握程度,明显是“用过但不懂”的硬凑。 4. **教育背景和自我评价全是“无效信息垃圾”** GPA前10%这么好的牌,只列“Java程序设计”这种基础课,分布式、微服务这些后端核心课提都不提,白瞎了专业优势;自我评价那堆“积极认真、细心负责”,是从招聘网站抄的模板吧?没有任何和项目挂钩的具体事例,比如“解决过XX bug”“优化过XX性能”,纯废话,看完等于没看。 总结:这简历是“技术名词缝合怪+自我感动式凑数”,看着像“背了后端技术栈名词的应届生”,实则没干货、没重点、没可信度——面试官扫30秒就会丢一边,因为连“你能干嘛”都没说清楚。
点赞 评论 收藏
分享
_mos_:要不是看评论区我都不知道你要找的是数分
点赞 评论 收藏
分享
评论
点赞
23
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务