牛客练习赛134 —— B题 python 补题 + 题解



牛客练习赛134 B


题目描述


在这里插入图片描述

示例输入:

1
5
1 2 4 5 6
2 5 4 6 9

示例输出:

32

在这里插入图片描述



解题思路:


题目大意

给定一个2行n列的矩阵,允许交换两列一次,从左上角(1,1)走到右下角(2,n),每一步只能向右或向下移动,求经过元素的最大和。

核心思路: 往下走只有一次,所以选择枚举往下走的分界点

  1. 路径结构分析
    路径必然在第一行右走若干列后下到第二行继续右走。设转折点为i(在第i列下移),路径和为第一行前i列的和 + 第二行in列的和。

  2. 不交换列的情况
    预处理第一行的前缀和sum1和第二行的后缀和sum2,遍历所有i,计算sum1[i]+sum2[i]的最大值。

  3. 交换列的增益计算
    通过预处理四个数组,分三种情况计算交换后的最大增益:

    • Case1:交换左半区某列与右半区某列,最大化差值之和。
    • Case2:交换左半区某列与当前列,提升当前列的第二行值。
    • Case3:交换右半区某列与当前列,提升当前列的第一行值。
  4. 边界处理
    单独处理i=1i=n的情况,分别考虑与右侧或左侧列交换的增益。

实现步骤

  1. 预处理前缀和与后缀和

    • sum1[i]:第一行前i列的和。
    • sum2[i]:第二行i到n列的和。
  2. 预处理最大值与差值数组

    • max1[i]i到n列第一行的最大值。
    • max2[i]前i列第二行的最大值。
    • diff1[i]i到n列(第一行-第二行)的最大差值。
    • diff2[i]前i列(第二行-第一行)的最大差值。
  3. 分情况计算最大路径和

    • 遍历中间转折点,计算三种交换情况的增益。
    • 单独处理首尾列的交换增益。


实现code:

t = int(input())
for _ in range(t):n = int(input())a1 = list(map(int, input().split()))a2 = list(map(int, input().split()))ans = -float('inf')if n == 1:  # 特判print(a1[0] + a2[0])continue# 第一行的前缀和:sum1[i]表示前i列第一行的元素和sum1 = [0] * (n + 1)for i in range(1, n + 1):sum1[i] = sum1[i - 1] + a1[i - 1]# 第二行的后缀和:sum2[i]表示从第i列到第n列第二行的元素和sum2 = [0] * (n + 2)for i in range(n, 0, -1):sum2[i] = sum2[i + 1] + a2[i - 1]# 枚举所有可能的分界点i,路径为:前i列走第一行,第i列到第n列走第二行for i in range(1, n + 1):ans = max(ans, sum1[i] + sum2[i])  # 不交换列的情况'''预处理max1,max2和diff1,diff2数组:max1[i]:第i列到第n列第一行的最大值max2[i]:前i列中第二行的最大值diff1[i]:第i列到第n列中(第一行元素 - 第二行元素)的最大差值diff2[i]:前i列中(第二行元素 - 第一行元素)的最大差值'''max1 = [-float('inf')] * (n + 2)diff1 = [-float('inf')] * (n + 2)for i in range(n, 0, -1):max1[i] = max(max1[i + 1], a1[i - 1])diff1[i] = max(diff1[i + 1], a1[i - 1] - a2[i - 1])max2 = [-float('inf')] * (n + 1)diff2 = [-float('inf')] * (n + 1)for i in range(1, n + 1):max2[i] = max(max2[i - 1], a2[i - 1])diff2[i] = max(diff2[i - 1], a2[i - 1] - a1[i - 1])# 交换列for i in range(2, n):# Case1:交换i左边某列和右边某列:找到最大的左边差值与右边差值之和case1 = sum1[i] + sum2[i] + diff2[i - 1] + diff1[i + 1]# Case2:交换i左边某列与当前列:当前列的第二行被替换为左边更大的值case2 = sum1[i] + sum2[i] - a2[i - 1] + max2[i - 1]# Case3:交换i右边某列与当前列:当前列的第一行被替换为右边更大的值case3 = sum1[i] + sum2[i] - a1[i - 1] + max1[i + 1]ans = max(ans, case1, case2, case3)# 特判:转折点为第一列,最后一列if n >= 2:# Case4:交换第一列与右边某列:第一列的第一行被替换为右边更大的值case4 = sum1[1] + sum2[1] - a1[0] + max1[2]# Case5:交换最后一列与左边某列:最后一列的第二行被替换为左边更大的值case5 = sum1[n] + sum2[n] - a2[n - 1] + max2[n - 1]ans = max(ans, case4, case5)print(ans)


END
如果有更多问题或需要进一步的帮助,可以在评论区留言讨论哦!
如果喜欢的话,请给博主点个关注 谢谢

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

电脑开机一段时间就断网,只有重启才能恢复网络(就算插网线都不行),本篇文章直接解决,不要再看别人的垃圾方法啦

下面的是我解决问题的心路历程,不想看的可以直接跳到解决方法上面! 内心思路: w11电脑更新过系统后,我的电脑是常年不关机的,但是一天突然断网,试了很多方法都连不上,重启电脑就会好&#xff0…

Ubuntu部署ktransformers

准备工作 一台服务器 CPU:500G GPU:48G(NVIDIA4090) 系统:Ubuntu20.04(github的文档好像用的是22.04) 第一步:下载权重文件 1.下载hfd wget https://hf-mirror.com/hfd/hfd.s…

【Elasticsearch】同一台服务器部署集群

【Elasticsearch】同一台服务器部署集群 1. 同一台服务器搭建ES集群2. 配置不同的node节点3. ES集群中安装IK分词器4. 启动es集群5. Kibana访问集群6. es-head7. 集群中创建索引7.1 什么是分片以及分片的好处7.2 副本(Replication)7.3 通过es-head创建索…

1-1 VS Code+Keil5+STM32CubeMX开发环境搭建

1.0 卸载相关程序 使用这个方式安装工具,先将原先下载安装的软件去掉,然后再安装新的软件,这个卸载过程需要将原来的工具干净的卸载掉,使用专门的卸载工具,将注册表等文件也全部删除掉。 对于STM32CubeMX还要删除&…

C# 从基础神经元到实现在0~9数字识别

训练图片:mnist160 测试结果:1000次训练学习率为0.1时,准确率在60%以上 学习的图片越多,训练的时候越长(比如把 epochs*10 10000或更高时)效果越好 using System; using System.Collections.Generic; using System.Drawing; using System.IO; using System.Windo…

【算法与数据结构】单调队列

目录 单调队列 使用单调队列维护滑动窗口 具体过程: 代码实现: 复杂度分析: 使用单调队列优化动态规划 例题 单调队列 单调队列(deque)是一种特殊的队列,队列中的元素始终按严格递增或者递减排列。这样就可以保证队头元素…

矩阵的扩展运算(MATLAB和pytorch实例)

秩(Rank)的定义 秩的计算 初等行变换法(最常用)行列式法(仅适用于方阵) 满秩的分类方阵的满秩非方阵的满秩几何意义应用场景判断方法 矩阵的特征值 定义求解特征值 特征方程步骤 关键性质 迹与行列式相似矩…

python面试题整理

Python 如何处理异常? Python中,使用try 和 except 关键字来捕获和处理异常 try 块中放置可能会引发异常的代码,然后在except块中处理这些异常。 能补充一下finally的作用吗? finally 块中的代码无论是否发生异常都会执行&#xf…

linux之perf(17)PMU事件采集脚本

Linux之perf(17)PMU事件采集脚本 Author: Once Day Date: 2025年2月22日 一位热衷于Linux学习和开发的菜鸟,试图谱写一场冒险之旅,也许终点只是一场白日梦… 漫漫长路,有人对你微笑过嘛… 全系列文章可参考专栏: Perf性能分析_Once_day的博…

Java数据结构-排序

目录 一.本文关注焦点 二.七大排序分析及相关实现 1.冒泡排序 2.简单选择排序 3.直接插入排序 4.希尔排序 5.堆排序 ​编辑 6.归并排序 7.快速排序 一.本文关注焦点 各种排序的代码实现及各自的时间空间复杂度分析及稳定性。 时间复杂度:在比较排序中主…

改进收敛因子和比例权重的灰狼优化算法【期刊论文完美复现】(Matlab代码实现)

2 灰狼优化算法 2.1 基本灰狼优化算法 灰狼优化算法是一种模拟灰狼捕猎自然群体行为的社会启发式优化算法,属于一种新型的群体智能优化算法。灰狼优化算法具有高度的灵活性,是当前较为流行的优化算法之一。灰狼优化算法主要分为三个阶段:追…

创建Linux虚拟环境并远程连接

目录 下载VMware软件 下载CentOS 创建虚拟环境 远程连接Linux系统 下载VMware软件 不会的可以参考 传送门 下载CentOS 不会的可以参考 传送门 创建虚拟环境 打开VMware软件,创建虚拟机 选择典型安装 找到我们安装好的centOS文件,之后会自动检…

汽车智能制造企业数字化转型SAP解决方案总结

一、项目实施概述 项目阶段划分: 蓝图设计阶段主数据管理方案各模块蓝图设计方案下一阶段工作计划 关键里程碑: 2022年6月6日:项目启动会2022年12月1日:系统上线 二、总体目标 通过SAP实施,构建研产供销协同、业财一…

《Head First设计模式》读书笔记 —— 命令模式

文章目录 本节用例餐厅类比点餐流程角色与职责从餐厅到命令模式 命令模式第一个命令对象实现命令接口实现一个命令 使用命令对象NoCommand与空对象 定义命令模式支持撤销功能使用状态实现撤销多层次撤销 One One One …… more things宏命令使用宏命令 队列请求日志请求 总结 《…

基于YOLO11深度学习的运动鞋品牌检测与识别系统【python源码+Pyqt5界面+数据集+训练代码】

《------往期经典推荐------》 一、AI应用软件开发实战专栏【链接】 项目名称项目名称1.【人脸识别与管理系统开发】2.【车牌识别与自动收费管理系统开发】3.【手势识别系统开发】4.【人脸面部活体检测系统开发】5.【图片风格快速迁移软件开发】6.【人脸表表情识别系统】7.【…

DAY08 List接口、Collections接口、Set接口

学习目标 能够说出List集合特点1.有序2.允许存储重复的元素3.有带索引的方法(练习 add,remove,set,get) 能够使用集合工具类Collections类:static void sort(List<T> list) 根据元素的自然顺序 对指定列表按升序进行排序。static <T> void sort(List<T> lis…

shell编程总结

前言 shell编程学习总结&#xff0c;1万3千多字带你学习shell编程 往期推荐 14wpoc&#xff0c;nuclei全家桶&#xff1a;nuclei模版管理工具Nuclei 哥斯拉二开&#xff0c;免杀绕过规避流量检测设备 fscan全家桶&#xff1a;FscanPlus&#xff0c;fs&#xff0c;fscan适用…

OpenAI ChatGPT在心理治疗领域展现超凡同理心,通过图灵测试挑战人类专家

近期&#xff0c;一项关于OpenAI ChatGPT在心理治疗领域的研究更是引起了广泛关注。据报道&#xff0c;ChatGPT已经成功通过了治疗师领域的图灵测试&#xff0c;其表现甚至在某些方面超越了人类治疗师&#xff0c;尤其是在展现同理心方面&#xff0c;这一发现无疑为AI在心理健康…

【智能客服】ChatGPT大模型话术优化落地方案

本文原创作者:姚瑞南 AI-agent 大模型运营专家,先后任职于美团、猎聘等中大厂AI训练专家和智能运营专家岗;多年人工智能行业智能产品运营及大模型落地经验,拥有AI外呼方向国家专利与PMP项目管理证书。(转载需经授权) 目录 一、项目背景 1.1 行业背景 1.2 业务现…

【JavaWeb12】数据交换与异步请求:JSON与Ajax的绝妙搭配是否塑造了Web的交互革命?

文章目录 &#x1f30d;一. 数据交换--JSON❄️1. JSON介绍❄️2. JSON 快速入门❄️3. JSON 对象和字符串对象转换❄️4. JSON 在 java 中使用❄️5. 代码演示 &#x1f30d;二. 异步请求--Ajax❄️1. 基本介绍❄️2. JavaScript 原生 Ajax 请求❄️3. JQuery 的 Ajax 请求 &a…