算法学习--前缀和与差分

简介: 算法学习--前缀和与差分


一 前缀和

2615. 等值距离和 - 力扣(LeetCode)


在这个题目当中, 在考虑到使用一个 unordered_map<int, vector<int>> 储存相同数字的下标之后, 问题就变成了: 给定一个有序数组(这道题目当中存入 vector 的是下标, 在插入的时候自然就是有序的, 无需排序), 求这个数组中的一个数与其他所有数的差的绝对值之和, 这一点可以使用前缀和来解决, 用 s[i] 来表示数组 a 中的前 i 个数之和

前缀和中 s[] 的下标要从 1 开始, 如果 a[] 的下标也是从 1 开始的话, 就会配合默契, 但是如果说 a[] 的下标为 0 开始, 那么就用循环 i 依然从 1 开始, 但是用 a[i-1]


class Solution {
public:
    typedef long long LL;
    vector<long long> distance(vector<int>& nums) {
        unordered_map<int, vector<int>> mp;
        int n=nums.size();
        for(int i=0;i<n;i++){
            mp[nums[i]].push_back(i);
        }
        vector<LL> arr(n);
        // 写成匿名函数可以更方便的使用 distance 中的局部变量
        auto get_one=[&](vector<int>&  vec){
            int len_vec=vec.size();
            vector<LL> s(len_vec+1);
            s[0]=0;
            // a 的下标是从 0 开始的
            for(int i=0;i<len_vec;i++){
                s[i+1]=s[i]+vec[i];
            }
            // vec 的下标是从 0 开始的, 但是循环的时候 i 依然从 1 开始, 只是使用 vec[i-1]
            for(int i=1;i<=len_vec;i++){
                LL l=1LL*i*vec[i-1]-s[i];
                LL r=(s[len_vec]-s[i])-1LL*vec[i-1]*(len_vec-i);
                arr[vec[i-1]]=l+r;
            }
        };
        for(auto it:mp){
            get_one(it.second);
        }
        return arr;
    }
};


差分

相关文章
|
6天前
|
算法
【算法】前缀和——二维前缀和模板题
【算法】前缀和——二维前缀和模板题
|
6天前
|
算法
【算法】前缀和——前缀和
【算法】前缀和——前缀和
|
11天前
|
机器学习/深度学习 人工智能 资源调度
【博士每天一篇文献-算法】连续学习算法之HAT: Overcoming catastrophic forgetting with hard attention to the task
本文介绍了一种名为Hard Attention to the Task (HAT)的连续学习算法,通过学习几乎二值的注意力向量来克服灾难性遗忘问题,同时不影响当前任务的学习,并通过实验验证了其在减少遗忘方面的有效性。
28 12
|
4天前
|
算法 Java
掌握算法学习之字符串经典用法
文章总结了字符串在算法领域的经典用法,特别是通过双指针法来实现字符串的反转操作,并提供了LeetCode上相关题目的Java代码实现,强调了掌握这些技巧对于提升算法思维的重要性。
|
6天前
|
算法 NoSQL 中间件
go语言后端开发学习(六) ——基于雪花算法生成用户ID
本文介绍了分布式ID生成中的Snowflake(雪花)算法。为解决用户ID安全性与唯一性问题,Snowflake算法生成的ID具备全局唯一性、递增性、高可用性和高性能性等特点。64位ID由符号位(固定为0)、41位时间戳、10位标识位(含数据中心与机器ID)及12位序列号组成。面对ID重复风险,可通过预分配、动态或统一分配标识位解决。Go语言实现示例展示了如何使用第三方包`sonyflake`生成ID,确保不同节点产生的ID始终唯一。
go语言后端开发学习(六) ——基于雪花算法生成用户ID
|
11天前
|
存储 机器学习/深度学习 算法
【博士每天一篇文献-算法】连续学习算法之HNet:Continual learning with hypernetworks
本文提出了一种基于任务条件超网络(Hypernetworks)的持续学习模型,通过超网络生成目标网络权重并结合正则化技术减少灾难性遗忘,实现有效的任务顺序学习与长期记忆保持。
14 4
|
1月前
|
人工智能 算法 JavaScript
【算法】前缀和与差分
算法学习——前缀和与差分(含一维和二维)
20 4
【算法】前缀和与差分
|
11天前
|
存储 机器学习/深度学习 算法
【博士每天一篇文献-算法】连续学习算法之RWalk:Riemannian Walk for Incremental Learning Understanding
RWalk算法是一种增量学习框架,通过结合EWC++和修改版的Path Integral算法,并采用不同的采样策略存储先前任务的代表性子集,以量化和平衡遗忘和固执,实现在学习新任务的同时保留旧任务的知识。
50 3
|
12天前
|
存储 机器学习/深度学习 算法
【博士每天一篇文献-综述】基于脑启发的连续学习算法有哪些?附思维导图
这篇博客文章总结了连续学习的分类,包括经典方法(重放、正则化和稀疏化方法)和脑启发方法(突触启发、双系统启发、睡眠启发和模块化启发方法),并讨论了它们在解决灾难性遗忘问题上的优势和局限性。
13 2
|
6天前
|
算法 C++
【算法】前缀和算法——和可被K整除的子数组
【算法】前缀和算法——和可被K整除的子数组

热门文章

最新文章