蓝桥:重新排序(差分,python)

前言:

本题在模拟考试时还不会差分法,用纯暴力思路ac了60%的案列,之后看了蓝桥讲解,用差分做出来了(但对差分还是一知半解),最近学会了差分又来做本题,又卡在了技巧思路上,特写此篇博客来巩固一下,也希望能对大家有所帮助。对差分法还不了解的同学可以看此篇博客一维前缀和&一维差分(下篇讲解二维前缀和&二维差分)(超详细,python版,其他语言也很轻松能看懂)

问题描述:

给定一个数组 A 和一些查询 Li,Ri,求数组中第 Li 至第 Ri 个元素之和。
小蓝觉得这个问题很无聊,于是他想重新排列一下数组,使得最终每个查询结果的和尽可能地大。小蓝想知道相比原数组,所有查询结果的总和最多可以增加多少?

输入格式
输入第一行包含一个整数 n。
第二行包含 n 个整数 A1,A2,⋅⋅⋅,An,相邻两个整数之间用一个空格分隔。
第三行包含一个整数 m 表示查询的数目。
接下来 m 行,每行包含两个整数 Li、Ri,相邻两个整数之间用一个空格分隔。

输出格式
输出一行包含一个整数表示答案。

数据范围
对于 30% 的评测用例,n,m≤50;
对于 50% 的评测用例,n,m≤500;
对于 70% 的评测用例,n,m≤5000;
对于所有评测用例,1≤n,m≤105,1≤Ai≤106,1≤Li≤Ri≤n。

输入样例:

5
1 2 3 4 5
2
1 3
2 5

输出样例:

4

样例解释
原来的和为 6+14=20,重新排列为 (1,4,5,2,3) 后和为 10+14=24,增加了 4。

思路:

用暴力思路来考虑此题的话只需要在草稿纸上把图画出来(数组尽量再取长一些),会发现需要改变的数字与它所被查询的次数相关。

以下标索引来说,如果该索引值被区间包含的次数越多(并集次数越多),则需要把数组中最大的数放在该索引上。例:在题目例子中,数组0,1,2,3,4,5中,所有查询结束后这些索引对应的次数应为[0,1,2,2,1,1],所以要在两个2中放最大的数,1中放次大的数。

这样每次查询索引所被区间包含的次数为多少次时,每次查询改变索引下标出现的次数的时间复杂度为O(n),查询次数一多就会超时。

这时就要考虑差分了,把每次查询的时间复杂度降为O(1),但是本题差分如何差分呢?

定义差分数组时要理解本题的差分数组是干什么的!!!本题差分数组是用来统计区间出现的次数, 所以定义为全0(未进行查询前,每个区间出现次数为0次),这点很重要!!!

本题还有一个问题点,求出差分后如何把数一一放在对应位置上呢?

这里有个小技巧,因为本题差分数组的定义是区间出现的次数,那么可以对原数组和差分数组进行排序,然后对应位置上所有原数组*差分数组的和就是总和,对于未排序前的数组统计和也可以用这个方法来降低时间复杂度

# 计算nums_1,原数组的和
nums_1 = 0
for i in range(1, n + 1):nums_1 += c[i] * a[i]  # 计算nums_1# 对a和c进行排序
a.sort()  # 对数组a进行排序
c.sort()  # 对数组c进行排序# 计算nums_2,排序后的最大和
nums_2 = 0
for i in range(1, n + 1):nums_2 += c[i] * a[i]  # 计算nums_2

代码及详细注释:

# 读取输入
n = int(input())  # 输入一个整数n
a = list(map(int, input().split()))  # 输入长度为n的整数列表a
m = int(input())  # 输入一个整数m# 初始化数组a和b
a = [0, *a]  # 在a列表的开头插入一个0,使得a的下标从1开始
b = [0] * (n + 2)  # 初始化长度为n+2的全0列表b# 处理区间操作
for i in range(m):l, r = map(int, input().split())  # 输入一个区间[l, r]b[l] += 1  # 区间左端点l对应的b值加1b[r + 1] -= 1  # 区间右端点r+1对应的b值减1# 计算数组c
c = [0] * (n + 1)  # 初始化长度为n+1的全0列表c
for i in range(1, n + 1):c[i] = b[i] + c[i - 1]  # 计算c[i],即前缀和# 计算nums_1
nums_1 = 0
for i in range(1, n + 1):nums_1 += c[i] * a[i]  # 计算nums_1# 对a和c进行排序
a.sort()  # 对数组a进行排序
c.sort()  # 对数组c进行排序# 计算nums_2
nums_2 = 0
for i in range(1, n + 1):nums_2 += c[i] * a[i]  # 计算nums_2# 输出结果
print(nums_2 - nums_1)  # 输出最终结果

总结:

本题是第十三届蓝桥杯省赛的题,掌握了差分做起来会发现很简单,用纯暴力做法思考起来也不是很难。

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

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

相关文章

【超细完整版】C# WebService 通过URL生成WSDL文件和DLL文件 【生成篇】

目的 支持通过web url (自适应“?wsdl”的有无) 生成.wsdl文件 和 .dll文件 实现 将通过一个类的三部分来实现这些功能 获取url中的ClassName (GetClassNameFromUrl)转换为WSDL文件 (UrlToWsdlFile)转换为DLL文件 (…

【算法】数组-二分搜索法

对应力扣704题目 左闭右闭 public class Solution{ public static void main(String[] args){ int[] nums {1,2,3,4,5,6,7,8,9,10}; int target 5; Solution solution new Soulution(); int result solution.search( nums, target); System.out.println("找到值的位置…

利用代理IP突破地域限制:解锁全球网络访问攻略

利用代理IP突破地域限制,实现解锁全球网络访问,是一种常见的网络技术手段。以下是一份详细的攻略: 1. 理解代理IP: 代理IP就像一个中间人,你的请求先发送到代理服务器,然后由代理服务器去获取你想要访问的网…

【STL基础】vector、stack、queue、list、pair、map、unordered_map、set、unordered_set(详细讲解)

vector、list、pair、unordered_map、unordered_set、stack、queue 参考文章: (1)【apollo】泛型编程 与 STL (2)c stack用法 入门必看 超详细 (3)C中queue的用法(超详细&#xff0c…

C语言关于void类型的指针作为函数形参在使用时需要注意的坑

目录 前言 一、void*指针使用时不同编译器下的处理结果 二、void*指针传递的指针变量进行位运算时,一定要注意强制转换的类型,和值的取值范围 总结 前言 众所周知,void* 指针作为函数形参时,表示可以接受任意类型的参数&#xf…

C语言基础知识点(十七)结构体中只用指针来存储字符串

// 如果需要用结构存储字符串&#xff0c;用字符数组作为成员会比较简单 // 如果需要使用指向char的指针来进行存储&#xff0c;那么需要请求malloc来 // 为字符串分配合适的存储空间#include <stdio.h> #include <string.h> //提供strcpy()\strlen()的原型 #i…

Linux修改Redis密码

方法一&#xff1a;修改配置文件 找到Redis配置文件redis.conf&#xff0c;通常位于/etc/redis/或/usr/local/etc/目录 sudo vim /etc/redis/redis.conf找到requirepass指令&#xff0c;如果已经有这个指令&#xff0c;你可以直接修改密码&#xff0c;如果没有&#xff0c;添…

Python实战:上下文管理器与with语句

一、引言 在Python编程中&#xff0c;上下文管理器与with语句是实现资源高效管理的重要工具。当程序使用资源&#xff08;如文件、网络连接等&#xff09;时&#xff0c;我们需要确保这些资源在使用完毕后能够被正确地释放&#xff0c;以避免资源泄漏和程序崩溃。上下文管理器…

基于FFmpeg混流及录制rtmp直播流

1、什么是混流&#xff1f; 混流就是把多路音视频流合成单流。准确的说&#xff0c;混流应该叫做混音&#xff08;音频流&#xff09;混画面&#xff08;视频流&#xff09; 混流的过程包括解码、混流、编码和推流四个部分。混流这个环节包括做抖动缓冲&#xff0c;目的是把多…

GDPU Java 天码行空4

文章目录 一、实验目的二、实验内容及要求三、实验内容及要求1. 设计AnimalTool工具类&#xff0c;实现eat()函数多态性&#x1f496; AnimalDemo.java&#x1f338; 运行结果 2. 是猫是狗&#x1f496; DuoTaiDemo5.java&#x1f338; 运行结果 3. 太会了&#x1f496; DuoTai…

国内IP地址切换排行榜软件大全

随着互联网的飞速发展&#xff0c;IP地址切换技术在日常工作和生活中扮演着越来越重要的角色。无论是为了网络安全、访问特定地区网站&#xff0c;还是进行市场调研、网络爬虫等&#xff0c;IP地址切换都成为了不可或缺的工具。虎观代理将为您介绍国内较受欢迎的IP地址切换软件…

B004-springcloud alibaba 服务容错 Sentinel

目录 高并发带来的问题服务雪崩效应常见容错方案常见的容错思路隔离超时限流熔断降级 常见的容错组件 Sentinel入门什么是Sentinel微服务项目集成Sentinel核心库安装Sentinel控制台实现一个接口的限流 Sentinel的概念和功能基本概念重要功能 Sentinel规则流控规则三种流控模式三…

mybatis拦截器打印sql日志

前言 利用mybatis拦截器打印输出sql 操作 编写拦截器 package com.it2.excel01.interceptor;import java.text.DateFormat; import java.util.Date; import java.util.List; import java.util.Locale; import java.util.Properties;import lombok.extern.slf4j.Slf4j; impo…

深度学习——线性代数相关知识

线性代数基础知识 一、线性代数基础知识1、标量2、向量3、矩阵4、张量5、点积6、向量—矩阵积7、矩阵—矩阵乘法 二、小结 一、线性代数基础知识 本节将介绍简要地回顾一下部分基本线性代数内容&#xff0c;线性代数中的基本数学对象、算术和运算&#xff0c;并用数学符号和相…

基于SpringBoot的高校办公室行政事务管理系统

采用技术 基于SpringBoot的高校办公室行政事务管理系统的设计与实现~ 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;SpringBootMyBatis 工具&#xff1a;IDEA/Ecilpse、Navicat、Maven 页面展示效果 功能清单 教师信息管理 办公室管理 办公物资管…

软文营销应该怎么做?软文营销的关键

软文本营销不是一个简单的写作和发送文章的过程&#xff0c;而是一个从早期准备到软文本写作再到效果评估的综合运营管理过程。 步骤一&#xff1a;目标明确 目标是指目标用户&#xff0c;找出目标用户是什么样的群体&#xff0c;从而根据用户群体的画像进行软文准备。 步骤二…

C语言基础练习——Day13

目录 选择题 编程题 统计每个月兔子的总数 数列的和 选择题 1、如果x2014&#xff0c;下面函数的返回值是 int fun(unsigned int x) {int n 0;while(x 1){n;x x | (x 1);}return n; } A 20B 21C 23D 25 答案&#xff1a;C &#x1f4a1; 解析&#xff1a; 上面的代码中的x …

3000+人使用,这套人力资源数据分析工具还能这么用

中国科学院自动化研究所&#xff08;以下简称“自动化所”&#xff09;成立于1956年&#xff0c;是中国科学院率先布局成立的“人工智能创新研究院”的总体牵头单位&#xff0c;是中国最早开展智能科学与技术基础理论、关键技术和创新性应用研究的科研机构&#xff0c;也是中国…

ADAS-AEB系统详解

ADAS-AEB系统详解 AEB即自动紧急制动&#xff08;Automatic Emergency Braking&#xff09;&#xff0c;其通过雷达、摄像头共同监测前方车辆以及行人情况&#xff0c;若探测到潜在碰撞风险&#xff0c;系统将采取相应预警及制动措施&#xff0c;从而避免发生碰撞或减轻碰撞损…

加速量产化节奏!移远通信5G RedCap模组RG255C-CN顺利通过SRRC认证

近日&#xff0c;移远通信5G RedCap模组产品再传喜讯——RG255C-CN顺利通过SRRC&#xff08;无线电型号核准&#xff09;认证测试&#xff0c;成为领先行业的轻量化5G产品。 此前&#xff0c;该模组也已通过NAL&#xff08;电信设备进网许可&#xff09;、CCC&#xff08;中国强…