Cow Exhibition G的来龙去脉

[USACO03FALL] Cow Exhibition G - 洛谷

曲折经过

爆搜

一开始没什么好的想法,就针对每头奶牛去or不去进行了爆搜。

#include <cstdio>
#include <algorithm>
using namespace std;

#define maxn 405
int iq[maxn], eq[maxn];
int ans;
int n;

void dfs(int k, int sumiq, int sumeq) {
    //printf("k:%d,sumiq %d, sumeq %d\n", k, sumiq, sumeq);

    if (k == n + 1) {
    if (sumiq < 0 | sumeq < 0) {
    return;
    }
    ans = max(ans, sumiq + sumeq);
    return;
    }

    dfs(k + 1, sumiq + iq[k], sumeq + eq[k]);
    dfs(k + 1, sumiq, sumeq);
}

int main() {
    scanf("%d", &n);
    for (int i = 1; i <= n; i++) {
    scanf("%d %d", &iq[i], &eq[i]);
    }
    dfs(1, 0, 0);
    printf("%d\n", ans);
    return 0;
}

但这代码交上去有5个数据点T了,所以还是得想其他的办法,比如DP。 

二维DP

一开始设计了一个三维的状态,f[i][j][k]表示到第i头牛,智商和为j,情商和为k时的情商与智商和

但这数组有点太大了...

考虑到j,k两维的下标其实与数组值有一定关系,所以我们优化掉第三维,把状态改成f[i][j]表示到第i头牛,智商和为j时的情商和

又考虑到,智商和、情商和可能取到负数,为了保证数组下标的合法性,我们对数组下标整体进行了偏移

#include <cstdio>
#include <algorithm>
#include <cstring>
using namespace std;

#define maxn 405
#define maxm 2005

int iq[maxn], eq[maxn];
int ans, n;
int dp[maxn][maxm * maxn];

int main() {
	scanf("%d", &n);
	for (int i = 1; i <= n; i++) {
		scanf("%d %d", &iq[i], &eq[i]);
	}

	memset(dp, -0x3f, sizeof(dp));
	dp[0][400000] = 0;


	for (int i = 1; i <= n; i++) {
        //合理调整dp边界
		if (iq[i] >= 0) {
			for (int j = iq[i]; j <= 800000; j++) {
				//for (int j = 800000; j >= iq[i]; j--) {
				dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - iq[i]] + eq[i]);
				//printf("dp[%d][%d]:%d\n", i, j, dp[i][j]);
			}
		} else {
			for (int j = 0; j <= 800000 + iq[i]; j++) {
				dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - iq[i]] + eq[i]);
				//printf("dp[%d][%d]:%d\n", i, j, dp[i][j]);
			}
		}
	}


	for (int j = 400000; j <= 800000; j++) {//智商和不能为负
		//printf("%d\n", dp[n][j] + j - 400000);
		if (dp[n][j] > 0)//情商和不能为负
			ans = max(ans, dp[n][j] + j - 400000);
	}


	printf("%d\n", ans);

	return 0;
}

 一些细节:

  • dp数组初始化成很小的数而非0,因为情商和有可能取负数
  • dp[0][400000]=0,偏移后的数组400000相当于零坐标,是合法状态
  • dp边界的处理
  • 找答案时的处理,且注意答案对应的是dp[n][j]+j,再减去总体偏移量400000

但MLE..

正解

一维DP

利用滚动数组优化

#include <cstdio>
#include <algorithm>
#include <cstring>
using namespace std;

#define maxn 405
#define maxm 2005

int iq[maxn], eq[maxn];
int ans, n;
int dp[maxm * maxn];

int main() {
	scanf("%d", &n);
	for (int i = 1; i <= n; i++) {
		scanf("%d %d", &iq[i], &eq[i]);
	}

	memset(dp, -0x3f, sizeof(dp));
	dp[400000] = 0;


	for (int i = 1; i <= n; i++) {
		if (iq[i] >= 0) {

			for (int j = 800000; j >= iq[i]; j--) {
				dp[j] = max(dp[j], dp[j - iq[i]] + eq[i]);
				//printf("dp[%d][%d]:%d\n", i, j, dp[i][j]);
			}
		} else {
			for (int j = 0; j <= 800000 + iq[i]; j++) {
				dp[j] = max(dp[j], dp[j - iq[i]] + eq[i]);
				//printf("dp[%d][%d]:%d\n", i, j, dp[i][j]);
			}
		}
	}


	for (int j = 400000; j <= 800000; j++) {
		//printf("%d\n", dp[n][j] + j - 400000);
		if (dp[j] > 0)
			ans = max(ans, dp[j] + j - 400000);
	}


	printf("%d\n", ans);

	return 0;
}

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/627426.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Stm32串口搭配DMA实现自定义printf、scanf

前言:本文仅供学习参考使用&#xff0c;主要目的是让大家快速使用串口调试&#xff0c;文章所提及的GCC适用于Clion&#xff0c;Vscode等第三方编辑器的用户。作者有时间会继续更新^_^ 一、GCC环境 1、标准库 (1)、使用方法 在主函数while(1)初始化中&#xff0c;添加Seria…

【复试分数线】综合性985历年分数线汇总(第四弹)

国家线和34所自划线 可以看作是考研上岸最最最基础的门槛。真正决定你能不能进入复试的还要看院线&#xff08;复试分数线&#xff09;&#xff01;今天我将分析考信号的除C9、工科类985的其他7所985近三年复试分数线&#xff08;不包括2024&#xff09;&#xff0c;大家可以参…

Web前端开发 - 4 - CSS3动画

CSS3动画 一、 设计2D变换二、 设计3D变换三、 设计过渡动画四、设计帧动画 一、 设计2D变换 transform : none | <transform-function> /* <transform-function> 设置变换函数&#xff0c;可以是一个或多个变换函数列表。函数包括: martrix(x缩放,x倾斜,y倾斜,y…

玩转Matlab-Simscape(初级)-01-从一个简单模型开始学习之旅

** 玩转Matlab-Simscape&#xff08;初级&#xff09;- 01 - 从一个简单模型开始学习之旅 ** 目录 玩转Matlab-Simscape&#xff08;初级&#xff09;- 01 - 从一个简单模型开始学习之旅 前言一、从模板开始建模二、建模一个简单的连杆2.1 建模2.2 生成子系统 总结 前言 在产…

如何在 Windows 11/10 中恢复已删除的分区

在将重要数据存储在计算机上之前&#xff0c;许多用户会创建分区以更好地组织和管理他们的文件。此分区可以在内部硬盘驱动器或外部存储设备上创建。但是&#xff0c;有时可能会意外删除分区。如果发生这种情况&#xff0c;您可能想知道是否可以在不丢失任何信息的情况下恢复已…

适用于 Windows 8/10/11 的 10 大 PC 迁移工具:电脑克隆迁移软件

当您发现自己拥有一台新的 PC 或笔记本电脑时&#xff0c;PC 迁移变得至关重要。将数据从旧计算机传输到新计算机的过程似乎令人生畏&#xff0c;尤其是如果您是第一次这样做。迁移过程中数据丢失的潜在风险加剧了焦虑。为确保文件和系统设置的无缝无忧传输&#xff0c;使用专为…

初识C语言——第二十天

do while ()循环 do 循环语句; while(表达式); 句式结构&#xff1a; 执行过程&#xff1a; do while循环的特点&#xff1a; 代码练习&#xff1a; 二分法算法&#xff1a; int main() {int arr[] { 0,1,2,3,4,5,6,7,8,9};int k 7;//查找数字7&#xff0c;在arr这个数组…

prompt工程策略(三:使用 LLM 防护围栏创建系统提示)

原文&#xff1a;我是如何赢得GPT-4提示工程大赛冠军的 原文的原文&#xff1a; How I Won Singapore’s GPT-4 Prompt Engineering Competition &#xff01;&#xff01;本内容仅适用于具有 System Prompt&#xff08;系统提示&#xff09;功能的 LLM。具有这一功能的最著名 …

Python sort() 和 sorted() 的区别应用实例详解

大家好&#xff0c;今天针对 Python 中 sort() 和 sorted() 之间的区别&#xff0c;来一个实例详细解读。sort — 顾名思义就是排序的意思&#xff0c;它可以接收的对象为可迭代的数据类型。今天以列表为例子演示两者的不同点、相同点&#xff0c;以及其中一些常用的高级参数使…

【3dmax笔记】022:文件合并、导入、导出

文章目录 一、合并二、导入三、导出四、注意事项一、合并 只能合并 max 文件(高版本能够合并低版本模型,低版本不能合并高版本的模型)。点击【文件】→【导入】→【合并】: 选择要合并的文件,后缀名为3dmax默认的格式,max文件。 二、导入 点击【文件】→【导入】→【导…

NSSCTF中的1zjs、作业管理系统、finalrce、websign、简单包含、Http pro max plus

目录 [LitCTF 2023]1zjs [LitCTF 2023]作业管理系统 [SWPUCTF 2021 新生赛]finalrce exec()函数&#xff1a;php中exec介绍及使用_php exec-CSDN博客​​​​​​ 资料参考&#xff1a;RCE(远程命令执行)绕过总结_rce绕过-CSDN博客 [UUCTF 2022 新生赛]websign [鹏城杯 …

【校园论坛系统】分站式后台,多城市圈子论坛,校园圈子交流平台,二手发布市场,校园圈子论坛系统

简述 校园论坛系统是为学生们提供一个交流、分享信息、互相帮助的平台。它通常包括了各种分类的版块&#xff0c;例如学习交流、社团活动、二手交易、失物招领等等。用户可以在论坛上发帖&#xff0c;回复他人的帖子&#xff0c;也可以私信其他用户。此外&#xff0c;管理员还…

只用了三天就入门了Vue3?

"真的我学Vue3&#xff0c;只是为了完成JAVA课设" 环境配置 使用Vue3要去先下载Node.js。 就像用Python离不开pip包管理器一样。 Node.js — Run JavaScript Everywhere (nodejs.org) 下完Node.js去学习怎么使用npm包管理器&#xff0c;放心你只需要学一些基础的…

【数据结构】数据结构大汇总 {数据结构的分类总结:定义和特性、实现方式、操作与复杂度、适用场景、相关算法、应用实例}

一、线性结构 1.1 顺序表 定义和特性&#xff1a;顺序表是一种线性表的存储结构&#xff0c;它采用一段地址连续的存储单元依次存储线性表中的元素。顺序表具有随机访问的特性&#xff0c;即可以通过元素的下标直接访问元素。 实现方式&#xff1a;顺序表可以通过数组来实现&…

React Native 之 原生组件和核心组件(二)

原生组件 在 Android 开发中是使用 Kotlin 或 Java 来编写视图&#xff1b;在 iOS 开发中是使用 Swift 或 Objective-C 来编写视图。在 React Native 中&#xff0c;则使用 React 组件通过 JavaScript 来调用这些视图。在运行时&#xff0c;React Native 为这些组件创建相应的 …

第1章 初始Spring Boot【仿牛客网社区论坛项目】

第1章 初始Spring Boot【仿牛客网社区论坛项目】 前言推荐项目总结第1章初识Spring Boot&#xff0c;开发社区首页1.课程介绍2.搭建开发环境3.Spring入门体验IOC容器体验Bean的生命周期体验配置类体验依赖注入体验三层架构 4.SpringMVC入门配置体验响应数据体验响应Get请求体验…

Java应用程序的本地内存跟踪分析

本文将讨论本机内存跟踪 (NMT)&#xff0c;我们可以使用它来隔离在 VM 级别增长的任何异常内存。 1.什么是本机内存&#xff1f; 本机内存是指计算机系统上运行的应用程序或程序可直接访问的内存空间。它是程序在执行期间存储和操作数据的内存区域。本机内存不同于托管内存&a…

实物仿真平台设计方案:927-8路GMSL视频注入回灌的自动驾驶半实物仿真平台

8路GMSL视频注入回灌的自动驾驶半实物仿真平台 一、平台介绍 产品基于8路GMSL视频注入回灌的自动驾驶半实物仿真平台旨在提高实验室及研究生院师生在基础软件层开发、计算机视觉和深度学习方面的专业知识学习和实践能力&#xff0c;为师生提供一个稳定软件开发和多精度框…

【C++】认识C++(上)

目录 从C到C命名空间同名冲突命名空间的定义命名空间的使用 C的输入和输出缺省参数&#xff08;默认参数&#xff09; 从C到C C语言的出现是计算机科学和工程史上的一个重要里程碑&#xff0c;许多现代计算机语言都受C语言的影响。C语言是面向过程的&#xff0c;结构化和模块化…

优选算法——双指针2

题目一——有效三角形的个数 思路 先审题 举个例子&#xff0c;下面一个序列可分成4个三元组 然后我们论证哪个可以组成三角形即可 判断三个数能不能组成三角形&#xff1a;任意两边之和大于第三边 注意第一个和第四个&#xff0c;有人说&#xff0c;这不是两个相同的吗&#…