2023-08-12:用go语言写算法。实验室需要配制一种溶液,现在研究员面前有n种该物质的溶液,

每一种有无限多瓶,第i种的溶液体积为v[i],里面含有w[i]单位的该物质,

研究员每次可以选择一瓶溶液,

将其倒入另外一瓶(假设瓶子的容量无限),即可以看作将两个瓶子内的溶液合并,

此时合并的溶液体积和物质含量都等于之前两个瓶子内的之和。

特别地,如果瓶子A与B的溶液体积相同,那么A与B合并之后,

该物质的含量会产生化学反应,使得该物质含量增加x单位,

研究员的任务是配制溶液体积恰好等于c的,且尽量浓的溶液(即物质含量尽量多)。

研究员想要知道物质含量最多是多少?

对于所有数据,1 <= n, v[i], w[i], x, c <= 1000。

来自某红书。

来自左程云

答案2023-08-12:

大体步骤如下:

1.定义一个dp数组,长度为c+1,用来存储每个体积对应的最大物质含量。

2.初始化dp数组,将所有元素初始化为-1,表示尚未计算过。

3.对于每种溶液,如果其体积小于等于c,更新dp数组,将对应的物质含量设为其自身的物质含量。

4.开始从体积1到c的循环,对于每个体积i,在1到i/2的范围内循环,计算两个瓶子合并后的物质含量。

5.如果两个瓶子在dp数组中有对应的值,说明可以进行合并操作。

6.更新dp[i],将其设为之前两个瓶子内物质含量之和加上合并之后的额外物质增加量。

7.返回dp[c],即体积为c时的最大物质含量。

时间复杂度:代码中有两个嵌套循环,分别遍历n种溶液和体积范围,因此时间复杂度为O(n*c)。

空间复杂度:使用了一个长度为c+1的dp数组,因此空间复杂度为O(c+1),即O(c)。

go完整代码如下:

package main

import (
"fmt"
"math"
) func maxValue(v []int, w []int, x int, c int) int {
n := len(v)
dp := make([]int, c+1)
for i := range dp {
dp[i] = -1
}
for i := 0; i < n; i++ {
if v[i] <= c {
dp[v[i]] = int(math.Max(float64(dp[v[i]]), float64(w[i])))
}
}
for i := 1; i <= c; i++ {
for j := 1; j <= i/2; j++ {
if dp[j] != -1 && dp[i-j] != -1 {
dp[i] = int(math.Max(float64(dp[i]), float64(dp[j]+dp[i-j]+bonus(x, j, i-j))))
}
}
}
return dp[c]
} func bonus(x, j, k int) int {
if j == k {
return x
}
return 0
} func main() {
v := []int{5, 3, 4}
w := []int{2, 4, 1}
x := 4
c := 16
fmt.Println(maxValue(v, w, x, c))
}

rust完整代码如下:

fn max_value(v: &[i32], w: &[i32], x: i32, c: i32) -> i32 {
let n = v.len();
let mut dp = vec![-1; (c + 1) as usize]; for i in 0..n {
if v[i] <= c {
dp[v[i] as usize] = dp[v[i] as usize].max(w[i]);
}
} for i in 1..=c {
for j in 1..=(i / 2) {
if dp[j as usize] != -1 && dp[(i - j) as usize] != -1 {
let val = dp[j as usize] + dp[(i - j) as usize] + if j == (i - j) { x } else { 0 };
dp[i as usize] = dp[i as usize].max(val);
}
}
} dp[c as usize]
} fn main() {
let v = vec![5, 3, 4];
let w = vec![2, 4, 1];
let x = 4;
let c = 16; println!("{}", max_value(&v, &w, x, c));
}

c++完整代码如下:

#include <iostream>
#include <vector>
#include <algorithm> int maxValue(std::vector<int>& v, std::vector<int>& w, int x, int c) {
int n = v.size();
std::vector<int> dp(c + 1, -1); // dp[i] = -1, no solution to obtain volume i so far // Set values for naturally available volumes
for (int i = 0; i < n; i++) {
if (v[i] <= c) {
dp[v[i]] = std::max(dp[v[i]], w[i]);
}
} for (int i = 1; i <= c; i++) {
for (int j = 1; j <= i / 2; j++) {
if (dp[j] != -1 && dp[i - j] != -1) {
int val = dp[j] + dp[i - j] + (j == i - j ? x : 0);
dp[i] = std::max(dp[i], val);
}
}
} return dp[c];
} int main() {
std::vector<int> v = { 5, 3, 4 };
std::vector<int> w = { 2, 4, 1 };
int x = 4;
int c = 16; std::cout << maxValue(v, w, x, c) << std::endl; return 0;
}

c完整代码如下:

#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h> int maxValue(int* v, int* w, int x, int n, int c) {
int* dp = (int*)malloc((c + 1) * sizeof(int)); for (int i = 0; i <= c; i++) {
dp[i] = -1;
} for (int i = 0; i < n; i++) {
if (v[i] <= c) {
*(dp + v[i]) = (*(dp + v[i]) > w[i]) ? *(dp + v[i]) : w[i];
}
} for (int i = 1; i <= c; i++) {
for (int j = 1; j <= i / 2; j++) {
if (*(dp + j) != -1 && *(dp + i - j) != -1) {
*(dp + i) = (*(dp + i) > ((*(dp + j)) + (*(dp + i - j)) + (j == i - j ? x : 0)))
? *(dp + i) : ((*(dp + j)) + (*(dp + i - j)) + (j == i - j ? x : 0));
}
}
} int result = *(dp + c);
free(dp);
return result;
} int main() {
int v[] = { 5, 3, 4 };
int w[] = { 2, 4, 1 };
int x = 4;
int c = 16;
int n = sizeof(v) / sizeof(v[0]);
printf("%d\n", maxValue(v, w, x, n, c)); return 0;
}

2023-08-12:用go语言写算法。实验室需要配制一种溶液,现在研究员面前有n种该物质的溶液, 每一种有无限多瓶,第i种的溶液体积为v[i],里面含有w[i]单位的该物质, 研究员每次可以选择一瓶的更多相关文章

  1. 用C语言写个程序推算出是星期几?(用泰勒公式实现)

    在日常生活中,我们常常遇到要知道某一天是星期几的问题.有时候,我们还想知道历史上某一天是星期几.比如: “你出生的那一天是星期几啊?” “明年五一是不是星期天?我去找你玩?” 通常,解决这个问题的最简 ...

  2. 用C语言写解释器(一)——我们的目标

    声明 为提高教学质量,我所在的学院正在筹划编写C语言教材.<用C语言写解释器>系列文章经整理后将收入书中"综合实验"一章.因此该系列的文章主要阅读对象定为刚学完C语言的 ...

  3. C语言查找算法之顺序查找、二分查找(折半查找)

    C语言查找算法之顺序查找.二分查找(折半查找),最近考试要用到,网上也有很多例子,我觉得还是自己写的看得懂一些. 顺序查找 /*顺序查找 顺序查找是在一个已知无(或有序)序队列中找出与给定关键字相同的 ...

  4. c/c++面试总结---c语言基础算法总结2

    c/c++面试总结---c语言基础算法总结2 算法是程序设计的灵魂,好的程序一定是根据合适的算法编程完成的.所有面试过程中重点在考察应聘者基础算法的掌握程度. 上一篇讲解了5中基础的算法,需要在面试之 ...

  5. m_Orchestrate learning system---二十一、怎样写算法比较轻松

    m_Orchestrate learning system---二十一.怎样写算法比较轻松 一.总结 一句话总结:(1.写出算法步骤,这样非常有利于理清思路,这样就非常简单了 2.把问题分细,小问题用 ...

  6. LaTeX 写算法伪码

    本系列文章由 @YhL_Leo 出品,转载请注明出处. 文章链接: http://blog.csdn.net/yhl_leo/article/details/50054953 LaTeX写算法伪码,需 ...

  7. 尚学python课程---12、python语言介绍

    尚学python课程---12.python语言介绍 一.总结 一句话总结: 1.操作简单:简便计算:允许通过单个“import”语句后跟一个函数调用来完成复杂的计算.虽慢 2.库丰富:比如人工智能和 ...

  8. 自己用C语言写单片机PIC18 serial bootloader

    了解更多关于bootloader 的C语言实现,请加我QQ: 1273623966 (验证信息请填 bootloader),欢迎咨询或定制bootloader(在线升级程序). HyperBootlo ...

  9. 自己用C语言写单片机PIC16 serial bootloader

    了解更多关于bootloader 的C语言实现,请加我QQ: 1273623966 (验证信息请填 bootloader),欢迎咨询或定制bootloader(在线升级程序). 为什么自己写bootl ...

  10. php调用一个c语言写的接口问题

    用php调用一个c语言写的soap接口时,遇到一个问题:不管提交的数据正确与否,都无法请求到接口 1.用php标准的soap接口去请求 2.拼接xml数据去请求 以上两种方式都不正确 解决办法:php ...

随机推荐

  1. 2022-12-02:有a块草莓蛋糕,有b块芝士蛋糕,两人轮流拿蛋糕, 每次不管是谁只能选择在草莓蛋糕和芝士蛋糕中拿一种, 拿的数量在1~m之间随意, 谁先拿完最后的蛋糕谁赢。 返回先手赢还是后手赢。

    2022-12-02:有a块草莓蛋糕,有b块芝士蛋糕,两人轮流拿蛋糕, 每次不管是谁只能选择在草莓蛋糕和芝士蛋糕中拿一种, 拿的数量在1~m之间随意, 谁先拿完最后的蛋糕谁赢. 返回先手赢还是后手赢. ...

  2. 2021-02-04:第一年农场有1只成熟的母牛A,往后的每年:①每一只成熟的母牛都会生一只母牛 ②每一只新出生的母牛都在出生的第三年成熟 ③每一只母牛永远不会死 。请问N年后牛的数量是多少 ?

    2021-02-04:第一年农场有1只成熟的母牛A,往后的每年:①每一只成熟的母牛都会生一只母牛 ②每一只新出生的母牛都在出生的第三年成熟 ③每一只母牛永远不会死 .请问N年后牛的数量是多少 ?福哥答 ...

  3. 2022-01-20: 矩形区域不超过 K 的最大数值和。 给你一个 m x n 的矩阵 matrix 和一个整数 k ,找出并返回矩阵内部矩形区域的不超过 k 的最大数值和。 题目数据保证总会存在一

    2022-01-20: 矩形区域不超过 K 的最大数值和. 给你一个 m x n 的矩阵 matrix 和一个整数 k ,找出并返回矩阵内部矩形区域的不超过 k 的最大数值和. 题目数据保证总会存在一 ...

  4. LeetCode 周赛 345(2023/05/14)体验一题多解的算法之美

    本文已收录到 AndroidFamily,技术和职场问题,请关注公众号 [彭旭锐] 提问. 往期回顾:LeetCode 双周赛第 104 场 · 流水的动态规划,铁打的结构化思考 周赛概览 T1. 找 ...

  5. vue全家桶进阶之路23:Element UI

    Element UI 是一套基于 Vue.js 的组件库,它提供了一系列常用的 UI 组件,包括表单.弹窗.布局.导航等等.Element UI 的设计风格简洁.易用.美观,且易于定制. Elemen ...

  6. 时间函数strftime和strptime的差别

    strftime是转换为特定格式输出, strptime是将一个时间字符串解析为时间类型对象. strftime是按照想要的格式,去转换.重点是格式! strptime不管什么格式,只要把特定的时间字 ...

  7. 【GiraKoo】Riters瑞特斯闹钟说明书

    对于闹钟这种按钮存在大量复用,长按操作的设备.说明书一旦丢失,真的很麻烦. 特准备了一个系列,专门保存使用说明书.希望能给大家提供一点帮助. 型号:RTS-1909

  8. ES 数据没了?谁动了我的数据?

    背景 我们在使用 Elasticsearch 的时候,可能会遇到数据"丢"了的情况.有可能是数据没成功写入 ES 集群,也可能是数据被误删了. 针对数据被误删,有没有好的解决办法呢 ...

  9. springboot 整合druid和mybatis

    Shrio+Mybatis+Druid 1.导入相关依赖包 2.在配置文件配置数据源 3.pojo对应实体类和mapper目录下的接口UserMapper (3.使用注解版) package com. ...

  10. cookie和session以及token

    cookie和seesion以及token 技术都基于状态保持, cookie: ​ 有服务器生成, 以 k:v 形式保持在浏览器端,下次请求服务器,附带cookie信息:存在恶意修改可能:可以对co ...