中位数贪心|前缀和_距离和ret=l+r_1

数据按排序后,处于中间位置的数值(数据个数奇数取正中间,偶数取中间两个的平均值)

lc462

class Solution {

public:

int minMoves2(vector<int>& nums) {

int m = nums.size() / 2;

++ranges::nth_element(nums, nums.begin() + m);++

++int mid = nums[m];++

int ans = 0;

for (int x : nums) {

++ans += abs(x - mid);++

}

return ans;

}

};

lc2033

class Solution {

/*

输入:grid = [[2,4],[6,8]], x = 2

输出:4

*/

public:

int minOperations(vector<vector<int>>& grid, int x)

{

vector<int> a;

for(auto& g:grid)

{

for(auto& e:g)

a.push_back(e);

}

int n=a.size();

int m=n/2;

++ranges::nth_element(a,a.begin()+m);
int mid=a[m];
++

int ret=0;

for(auto& b:a)

{

int d=abs(b-mid);

if(d%x!=0)

return -1;

ret+=(d/x);

}

return ret;

}

};

lc2602

排序+前缀和+二分

++right = sum[n] - sum[j] - q * (n - j); // 绿色面积++

使数组元素 全部等于某个元素的最小操作数

从q*n优化为(q+n)*log n

class Solution {

public:

vector<long long> minOperations(vector<int>& nums, vector<int>& queries) {

ranges::sort(nums);

int n = nums.size();

vector<long long> sum(n + 1); // 前缀和

for (int i = 0; i < n; i++) {

sum[i + 1] = sum[i] + nums[i];

}

int m = queries.size();

vector<long long> ans(m);

for (int i = 0; i < m; i++) {

int q = queries[i];

long long j = ranges::lower_bound(nums, q) - nums.begin();

long long left = q * j - sum[j]; // 蓝色面积

long long ++right = sum[n] - sum[j] - q * (n - j); // 绿色面积++

ans[i] = left + right;

}

return ans;

}

};

lower_bound 返回有序容器中++第一个≥目标值的元素迭代器++

upper_bound 返回第一个>目标值的元素迭代器(均基于二分查找,仅匹配条件不同)

lc2615

hash分组+前缀和求距离和

++ret[q] = left + right;++

class Solution {

typedef long long ll;

public:

vector<long long> distance(vector<int>& nums) {

int n=nums.size();

unordered_map<int,vector<int>> hash;

vector<ll> ret(n);

for(int i=0;i<n;i++)

{

hash[nums[i]].push_back(i);

}

for(auto& [_,b]:hash)

{

int m=b.size();

if(m==1)

{

ret[b[0]]=0;

continue;

}

vector<ll> p(m+1);

for(int i=1;i<=m;i++)

p[i]=p[i-1]+b[i-1];

for(int i=0;i<m;i++)

{

int q=b[i];

ll left = (ll)q*i-p[i]; // blue

ll right = p[m] - p[i] - (ll)q * (m - i); //green

++ret[q] = left + right;++

}

}

return ret;

}

};

相关推荐
草履虫建模17 小时前
力扣算法 1768. 交替合并字符串
java·开发语言·算法·leetcode·职场和发展·idea·基础
naruto_lnq19 小时前
分布式系统安全通信
开发语言·c++·算法
Jasmine_llq19 小时前
《P3157 [CQOI2011] 动态逆序对》
算法·cdq 分治·动态问题静态化+双向偏序统计·树状数组(高效统计元素大小关系·排序算法(预处理偏序和时间戳)·前缀和(合并单个贡献为总逆序对·动态问题静态化
爱吃rabbit的mq20 小时前
第09章:随机森林:集成学习的威力
算法·随机森林·集成学习
(❁´◡`❁)Jimmy(❁´◡`❁)21 小时前
Exgcd 学习笔记
笔记·学习·算法
YYuCChi21 小时前
代码随想录算法训练营第三十七天 | 52.携带研究材料(卡码网)、518.零钱兑换||、377.组合总和IV、57.爬楼梯(卡码网)
算法·动态规划
不能隔夜的咖喱21 小时前
牛客网刷题(2)
java·开发语言·算法
VT.馒头21 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript
进击的小头1 天前
实战案例:51单片机低功耗场景下的简易滤波实现
c语言·单片机·算法·51单片机
咖丨喱1 天前
IP校验和算法解析与实现
网络·tcp/ip·算法