【数据结构-距离合】力扣1685. 有序数组中差绝对值之和

server/2025/1/12 22:50:47/

给你一个 非递减 有序整数数组 nums 。

请你建立并返回一个整数数组 result,它跟 nums 长度相同,且result[i] 等于 nums[i] 与数组中所有其他元素差的绝对值之和。

换句话说, result[i] 等于 sum(|nums[i]-nums[j]|) ,其中 0 <= j < nums.length 且 j != i (下标从 0 开始)。

示例 1:
输入:nums = [2,3,5]
输出:[4,3,5]
解释:假设数组下标从 0 开始,那么
result[0] = |2-2| + |2-3| + |2-5| = 0 + 1 + 3 = 4,
result[1] = |3-2| + |3-3| + |3-5| = 1 + 0 + 2 = 3,
result[2] = |5-2| + |5-3| + |5-5| = 3 + 2 + 0 = 5。

示例 2:
输入:nums = [1,4,6,8,10]
输出:[24,15,13,15,21]
在这里插入图片描述

class Solution {
public:vector<int> getSumAbsoluteDifferences(vector<int>& nums) {int n = nums.size(),leftSum = 0,rightSum = accumulate(nums.begin(),nums.end(), 0);vector<int> result(n);for(int i = 0;i < n;i++){rightSum -= nums[i];result[i] = i * nums[i] - leftSum + rightSum - (n-1-i) * nums[i];leftSum += nums[i];}return result;}
};
对于i的左边:
nums[i]必然大于左边的所有元素,所以可以数出左边的元素个数,即i个
result[i] = (nums[i] - nums[0]) + (nums[i] - nums[1]) + ......+(nums[i] - nums[i - 1])
合并后就为:
result[i] = i * nums[i] - (nums[0] + nums[1] + ... + nums[i - 1])= i * nums[i] - leftsum

以上代码来源:
在这里插入图片描述

由于题目给的数组是非递减的,经过数学变化,可以得到每个元素和其他元素的绝对值之和与该元素以及左边元素和及右边元素和之间的关系,进行计算即可。


http://www.ppmy.cn/server/105225.html

相关文章

深入理解Elasticsearch:让搜索性能飞起来!

Elasticsearch 概述 Elasticsearch是一个基于lucene、分布式、通过Restful方式进行交互的近实时搜索平台框架。 ELK 技术栈是Elasticsearch、Logstash、Kibana三大开元框架首字母大写简称。 而Elasticsearch 是一个开源的高扩展的分布式全文搜索引擎&#xff0c; 是整个 ELK技术…

【十四届蓝桥杯省赛C++试卷】

一、选择题 第一题 C 中&#xff0c; bool 类型的变量占用字节数为&#xff08; &#xff09;。 A 、 1 B 、 2 C 、 3 D 、 4 答案&#xff1a;A 解析&#xff1a;&#xff08;C 中 bool 类型与 char 类型一样&#xff0c;都需要1 byte。一些其他类型的占用字节数&…

jmespath用法总结

JMESPath&#xff08;JSON.MetaExpression Syntax&#xff09;是一种查询和过滤JSON文档的表达式语言。JMESPath表达式可以提取、转换和计算JSON数据&#xff0c;以便于处理。JMESPath表达式由路径、过滤器和投影器组成&#xff0c;可以非常灵活地操作JSON数据。 下面是JMESPat…

如何设置PowerBI报告展示在屏幕的大小?

问题描述: 业务部门同事反馈&#xff0c;将开发的Power BI报告发布到Power BI服务站点后&#xff0c;用户通过不同尺寸的电子设备打开报告看到的效果不一样&#xff0c;如用PC打开报告可以在一屏中完整显示所有报告可视化组件如图&#xff1a; 但是用手机或者PAD类小尺寸电子设…

海运整箱成本与拼箱成本对比 | 国际贸易服务平台 | 箱讯科技

整箱和拼箱 在集装箱运输业务中&#xff0c;我们把一个集装箱、一个出口人、一个收货人、一个目的港&#xff0c;满足这“四个一”条件的货物叫做整箱货&#xff0c;而把一个集装箱、出口人、收货人和目的港这三项之中只要有一项是在两个或两个以上的出口运输货物&#xff0c;就…

泛微E9如何更新缓存

泛微E9如何更新缓存 在E9中&#xff0c;是默认开启了数据缓存的&#xff0c;如果直接操作数据库是会存在缓存不更新的问题&#xff0c;E9系统提供以下几种方式进行缓存清空的方式。 注&#xff1a;原则上禁止通过非程序渠道直接修改OA数据库数据&#xff0c;可以直接在页面进行…

plsql表格怎么显示中文 plsql如何导入表格数据

在Oracle数据库开发中&#xff0c;PL/SQL Developer是一款广泛使用的集成开发环境&#xff08;IDE&#xff09;&#xff0c;它提供了丰富的功能来帮助开发人员高效地进行数据库开发和管理。在使用PL/SQL Developer时&#xff0c;许多用户会遇到表格显示中文的问题&#xff0c;以…

什么是营销自动化?营销自动化的优势?

在SaaS行业和软件行业中&#xff0c;营销自动化作为一种先进的营销手段&#xff0c;正逐渐受到企业的青睐。营销自动化基于大数据和人工智能技术&#xff0c;能够自动执行、管理和完成营销任务和流程&#xff0c;为企业带来诸多优势。 营销自动化是一种能够一体化执行、管理、…