题目:配置魔药

2024-03-27 02:20
文章标签 配置 题目 魔药

本文主要是介绍题目:配置魔药,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目描述

【问题描述】
在《Harry Potter and the Chamber of Secrets》中,Ron的魔杖因为坐他老爸的Flying Car撞到了打人柳,不幸被打断了,从此之后,他的魔杖的魔力就大大减少,甚至没办法执行他施的魔咒,这为Ron带来了不少的烦恼。这天上魔药课,Snape要他们每人配置一种魔药(不一定是一样的),Ron因为魔杖的问题,不能完成这个任务,他请Harry在魔药课上(自然是躲过了Snape的检查)帮他配置。现在Harry面前有两个坩埚,有许多种药材要放进坩埚里,但坩埚的能力有限,无法同时配置所有的药材。一个坩埚相同时间内只能加工一种药材,但是不一定每一种药材都要加进坩埚里。加工每种药材都有必须在一个起始时间和结束时间内完成(起始时间所在的那一刻和结束时间所在的那一刻也算在完成时间内),每种药材都有一个加工后的药效。现在要求的就是Harry可以得到最大的药效。
出自:宜昌一中

输入格式

【输入】
输入文件的第一行有2个整数,一节魔药课的t(1≤t<≤500)和药材数n(1≤n≤100)。
输入文件第2行到n+1行中每行有3个数字,分别为加工第i种药材的起始时间t1、结束时间t2、(1≤t1≤t2≤t)和药效w(1≤w≤100)。

输出格式

【输出】
输出文件medic.out只有一行,只输出一个正整数,即为最大药效。

 

 

 

题解:

第一次做双线程动态规划,所以也就花了我星期三一个晚自习的时间。

设f[i][j]为坩埚1在第 i 的时间与坩埚2在第 j 的时间内所得最大药效。

可得动态转移方程:

f[i][j]=max{f[i][j],f[a[k][1]-1][j]}  //i>=a[k][2]

f[i][j]=max{f[i][j],f[i][a[k][1]-1]} //j>=a[k][2]

满足了第 k 个物品只取入一个坩埚或不取。

当然,仅仅是这样还是不能保证能求出最优解,因为在计算过程中,结构会被刷新,因此对于结束时间较晚的药材,若在结束时间较前的药材先被计算,则较前的药材就以为价值小而不会被记录,因此就应该在动态规划之前将数据按结束时间a[i][2](即结束时间)升序排序。或者晚结束的药材更新的时候需要早结束的都更新过了的状态,方程才得以转移。

View Code
 1 #include<iostream>
2 using namespace std;
3
4 int f[501][501]={0},a[101][3],w[101],n,m;
5
6 void quick(int l,int r){
7 if(l>=r) return ;
8 int i=l,j=r,mid=a[(l+r)/2][2];
9 while(i<=j)
10 {
11 while(a[i][2]<mid) i++;
12 while(a[j][2]>mid) j--;
13 if(i<=j)
14 {
15 if(a[i][2]==a[j][2]&&a[i][1]>a[j][1])
16 {i++;j--;continue;}
17 swap(a[i][1],a[j][1]);swap(a[i][2],a[j][2]);swap(w[i],w[j]);i++;j--;}
18 }
19 quick(l,j);
20 quick(i,r);
21
22 }
23
24 int main()
25 {
26 int i,j,k,l,z;
27 cin>>m>>n;
28
29 for(i=1;i<=n;i++)
30 cin>>a[i][1]>>a[i][2]>>w[i];
31
32 quick(1,n);
33
34 for(i=1;i<=n;i++)
35 for(k=m;k>=0;k--)
36 for(j=m;j>=0;j--)
37 {
38 if(j>=a[i][2]) f[j][k]=max(f[j][k],f[a[i][1]-1][k]+w[i]);
39 if(k>=a[i][2]) f[j][k]=max(f[j][k],f[j][a[i][1]-1]+w[i]);
40 }
41
42 cout<<f[m][m]<<endl;
43
44 return 0;
45
46 }

 

 

      

转载于:https://www.cnblogs.com/noip/archive/2012/02/22/2363827.html

这篇关于题目:配置魔药的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/850651

相关文章

SpringBoot结合Knife4j进行API分组授权管理配置详解

《SpringBoot结合Knife4j进行API分组授权管理配置详解》在现代的微服务架构中,API文档和授权管理是不可或缺的一部分,本文将介绍如何在SpringBoot应用中集成Knife4j,并进... 目录环境准备配置 Swagger配置 Swagger OpenAPI自定义 Swagger UI 底

Oracle迁移PostgreSQL隐式类型转换配置指南

《Oracle迁移PostgreSQL隐式类型转换配置指南》Oracle迁移PostgreSQL时因类型差异易引发错误,需通过显式/隐式类型转换、转换关系管理及冲突处理解决,并配合验证测试确保数据一致... 目录一、问题背景二、解决方案1. 显式类型转换2. 隐式转换配置三、维护操作1. 转换关系管理2.

IDEA中配置Tomcat全过程

《IDEA中配置Tomcat全过程》文章介绍了在IDEA中配置Tomcat的六步流程,包括添加服务器、配置部署选项、设置应用服务器及启动,并提及Maven依赖可能因约定大于配置导致问题,需检查依赖版本... 目录第一步第二步第三步第四步第五步第六步总结第一步选择这个方框第二步选择+号,找到Tomca

Win10安装Maven与环境变量配置过程

《Win10安装Maven与环境变量配置过程》本文介绍Maven的安装与配置方法,涵盖下载、环境变量设置、本地仓库及镜像配置,指导如何在IDEA中正确配置Maven,适用于Java及其他语言项目的构建... 目录Maven 是什么?一、下载二、安装三、配置环境四、验证测试五、配置本地仓库六、配置国内镜像地址

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Debian系和Redhat系防火墙配置方式

《Debian系和Redhat系防火墙配置方式》文章对比了Debian系UFW和Redhat系Firewalld防火墙的安装、启用禁用、端口管理、规则查看及注意事项,强调SSH端口需开放、规则持久化,... 目录Debian系UFW防火墙1. 安装2. 启用与禁用3. 基本命令4. 注意事项5. 示例配置R

PyCharm中配置PyQt的实现步骤

《PyCharm中配置PyQt的实现步骤》PyCharm是JetBrains推出的一款强大的PythonIDE,结合PyQt可以进行pythion高效开发桌面GUI应用程序,本文就来介绍一下PyCha... 目录1. 安装China编程PyQt1.PyQt 核心组件2. 基础 PyQt 应用程序结构3. 使用 Q

Redis MCP 安装与配置指南

《RedisMCP安装与配置指南》本文将详细介绍如何安装和配置RedisMCP,包括快速启动、源码安装、Docker安装、以及相关的配置参数和环境变量设置,感兴趣的朋友一起看看吧... 目录一、Redis MCP 简介二、安www.chinasem.cn装 Redis MCP 服务2.1 快速启动(推荐)2.

Spring Boot配置和使用两个数据源的实现步骤

《SpringBoot配置和使用两个数据源的实现步骤》本文详解SpringBoot配置双数据源方法,包含配置文件设置、Bean创建、事务管理器配置及@Qualifier注解使用,强调主数据源标记、代... 目录Spring Boot配置和使用两个数据源技术背景实现步骤1. 配置数据源信息2. 创建数据源Be

Spring Boot Maven 插件如何构建可执行 JAR 的核心配置

《SpringBootMaven插件如何构建可执行JAR的核心配置》SpringBoot核心Maven插件,用于生成可执行JAR/WAR,内置服务器简化部署,支持热部署、多环境配置及依赖管理... 目录前言一、插件的核心功能与目标1.1 插件的定位1.2 插件的 Goals(目标)1.3 插件定位1.4 核