2022-05-31:某公司游戏平台的夏季特惠开始了,你决定入手一些游戏。现在你一共有X元的预算。
该平台上所有的 n 个游戏均有折扣,标号为 i 的游戏的原价a_i元,现价只要b_i元,
也就是说该游戏可以优惠 a_i - b_i,并且你购买该游戏能获得快乐值为 w_i,
由于优惠的存在,你可能做出一些冲动消费导致最终买游戏的总费用超过预算,
只要满足 : 获得的总优惠金额不低于超过预算的总金额,
那在心理上就不会觉得吃亏。
现在你希望在心理上不觉得吃亏的前提下,获得尽可能多的快乐值。
来自字节内部训练营。
来自力扣bytedance-006. 夏季特惠。

答案2022-05-31:

转化之后是背包问题。

代码用rust编写。代码如下:

  1. fn main() {
  2. let sc: Vec<isize> = vec![4, 100, 100, 73, 60, 100, 89, 35, 30, 21, 30, 10, 8, 10];
  3. let mut ii: isize = 0;
  4. while ii < sc.len() as isize {
  5. let n = sc[ii as usize];
  6. ii += 1;
  7. let mut money = sc[ii as usize];
  8. ii += 1;
  9. let mut costs: Vec<isize> = vec![];
  10. for _i in 0..n {
  11. costs.push(0);
  12. }
  13. let mut values: Vec<isize> = vec![];
  14. for _i in 0..n {
  15. values.push(0);
  16. }
  17. let mut size: isize = 0;
  18. let mut ans: isize = 0;
  19. for _i in 0..n {
  20. // 打折前
  21. let pre = sc[ii as usize];
  22. ii += 1;
  23. // 打折后
  24. let pos = sc[ii as usize];
  25. ii += 1;
  26. // 满足度
  27. let happy = sc[ii as usize];
  28. ii += 1;
  29. // 节省的钱(save) = 打折前(pre) - 打折后(pos)
  30. let save = pre - pos;
  31. // 带来的好处(well) = 节省的钱 - 打折后(pos)
  32. let well = save - pos;
  33. // 比如,一件"一定要买的商品":
  34. // 预算 = 100,商品原价 = 10,打折后 = 3
  35. // 那么好处 = (10 - 3) - 3 = 4
  36. // 所以,这件商品把预算增加到了104,一定要买
  37. // 接下来,比如一件"需要考虑的商品",预算 = 104,商品原价 = 10,打折后 = 8
  38. // 那么好处 = (10 - 8) - 8 = -6
  39. // 这件商品,就花掉6元!
  40. // 也就是说,以后花的不是打折后的值,是"坏处"
  41. let cost = -well;
  42. if well >= 0 {
  43. money += well;
  44. ans += happy;
  45. } else {
  46. costs[size as usize] = cost;
  47. values[size as usize] = happy;
  48. size += 1;
  49. }
  50. }
  51. let mut dp: Vec<Vec<isize>> = vec![];
  52. for i in 0..size + 1 {
  53. dp.push(vec![]);
  54. for _j in 0..money + 1 {
  55. dp[i as usize].push(0);
  56. }
  57. }
  58. for a in 0..=size {
  59. for b in 0..=money {
  60. dp[a as usize][b as usize] = -2;
  61. }
  62. }
  63. ans += process(&mut costs, &mut values, size, 0, money, &mut dp);
  64. println!("{}", ans);
  65. }
  66. }
  67. fn get_max<T: Clone + Copy + std::cmp::PartialOrd>(a: T, b: T) -> T {
  68. if a > b {
  69. a
  70. } else {
  71. b
  72. }
  73. }
  74. fn process(
  75. costs: &mut Vec<isize>,
  76. values: &mut Vec<isize>,
  77. size: isize,
  78. i: isize,
  79. money: isize,
  80. dp: &mut Vec<Vec<isize>>,
  81. ) -> isize {
  82. if money < 0 {
  83. return -1;
  84. }
  85. if i == size {
  86. return 0;
  87. }
  88. if dp[i as usize][money as usize] != -2 {
  89. return dp[i as usize][money as usize];
  90. }
  91. let p1 = process(costs, values, size, i + 1, money, dp);
  92. let mut p2 = -1;
  93. let next = process(costs, values, size, i + 1, money - costs[i as usize], dp);
  94. if next != -1 {
  95. p2 = values[i as usize] + next;
  96. }
  97. let ans = get_max(p1, p2);
  98. dp[i as usize][money as usize] = ans;
  99. return ans;
  100. }

执行结果如下:


左神java代码

bytedance-006. 夏季特惠

2022-05-31:某公司游戏平台的夏季特惠开始了,你决定入手一些游戏。现在你一共有X元的预算。 该平台上所有的 n 个游戏均有折扣,标号为 i 的游戏的原价a_i元,现价只要b_i元, 也就是说该的更多相关文章

  1. http://www.cnblogs.com/peida/archive/2013/05/31/3070790.html深入理解Java:SimpleDateFormat安全的时间格式化

    http://www.cnblogs.com/peida/archive/2013/05/31/3070790.html

  2. 梅安森元图地图开放平台、专业GIS地图平台

    元图地图开放平台:http://map.cmetamap.com/?from=groupmessage 梅安森元图地图开放平台: 自主知识产权,专业GIS地图平台,用简单语言即可轻松操作复杂的互联网地 ...

  3. Murano Weekly Meeting 2016.05.31

    Meeting time: 2016.May.31 1:00~2:00 Chairperson:  Kirill Zaitsev, from Mirantis Meeting summary: 1.A ...

  4. leetcode(三)——2020.05.31

    (上周7道题完成) 本周leetcode题目(from leetcode hot100): 15 17 19 21 33 94 42 额外完成: 22(回溯), 8, 31,200

  5. Cheatsheet: 2016 05.01 ~ 05.31

    Other Awesome Go - A curated list of awesome Go frameworks, libraries and software Visual Studio Cod ...

  6. Cheatsheet: 2015 05.01 ~ 05.31

    .NET .NET on Mac for the OS X n00b without Mono via Visual Studio Code Microsoft frameworks deprecat ...

  7. Cheatsheet: 2014 05.01 ~ 05.31

    Web Choosing a Web Framework/Language Combo for the Next Decade Optimizing NGINX and PHP-fpm for hig ...

  8. Contest2089 - 湖南多校对抗赛(2015.05.31) Swipe(csu1648)

    Problem E: Swipe Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 100  Solved: 15[Submit][Status][Web ...

  9. Android学习CursorWrapper与Decorator模式 (转至http://www.cnblogs.com/bastard/archive/2012/05/31/2527944.html)

    一 Decorator模式 意图: 动态的给一个对象添加一些额外的职责.就增加功能来说,Decorator模式相比生成子类更为灵活. 动态的给一个对象,而不是对整个类添加额外职责,说明此模式将采用的结 ...

  10. Cheatsheet: 2017 05.01 ~05.31

    Web Configuring Your .npmrc for an Optimal Node.js Environment Web Developer Security Checklist HTTP ...

随机推荐

  1. Https交互原理

    Http超文本传输协议 基于tcp和Ip实现的一种可靠的传输协议,可靠的保证了客户端和服务器之间的传输不会丢失,但是却没办法保证传输数据的安全性. Https是Http的升级版本,用于解决Http数据 ...

  2. Strus框架

    一.框架概述 1.框架的意义与作用: 所谓框架,就是把一些繁琐的重复性代码封装起来,使程序员在编码中把更多的经历放到业务需求的分析和理解上面. 特点:封装了很多细节,程序员在使用的时候会非常简单. 2 ...

  3. 自动化兼容性测试工具——WeTest

    这个作业属于哪个课程 2021春软件工程实践|W班(福州大学) 这个作业要求在哪里 软件工程实践总结&个人技术博客 这个作业的目标 分享自动化兼容性测试工具的使用 其他参考文献 ... 目录 ...

  4. Linux高并发服务器之Linux多线程开发

    本文源自C++高薪面试项目的学习笔记,主要记录Liunx多线程的学习,主要知识点是线程概述等基础概念以外,还有线程相关Liunx系统函数以及对应练手代码,除此之外还有线程同步问题的讲解以及实战多线程买 ...

  5. 痞子衡嵌入式:我拿到了CSDN博客专家实体证书

    「CSDN」作为中国最具人气的专业 IT 社区,一直是广大 IT 技术博主的主选阵地.这些年 CSDN 在知识付费领域的探索也远远超过其它平台,大家(尤其是创作型博主)对 CSDN 的认可度也越来越高 ...

  6. 继续Vue的探索

    接上集 上次到了想要利用Vue实现隔行变色的请求,但是由于使用的代码过于"高级"导致无法识别,这就需要利用webpack来解决它! webpack的基本使用 1.首先,在项目中安装 ...

  7. 搭建react的架手架

    1.回顾 cnpm i @vue/cli -g ----- 4的脚手架 ------ webpack 4 cnpm i @vue/cli@3 -g ----- 3的脚手架 ------ webpack ...

  8. 图与网络分析—R实现(五)

    四 最大流问题 最大流问题(maximum flow problem),一种网络最优化问题,就是要讨论如何充分利用装置的能力,使得运输的流量最大,以取得最好的效果.最大流问题是一类应用极为广泛的问题, ...

  9. 5.mapper出错原因

    1.总结:前个星期mapper出错,很大原因是自己的项目结构创建有问题,大项目下应该是spring init那种项目结构形式,但是在创建多模块的时候应该是使用moudle形式的项目结构: 所以自己在运 ...

  10. 多线程socketserver

    模块:socketserver tcp协议: 服务端: import socketserver class MyRequestHandle(socketserver.BaseRequestHandle ...