篮桥云课-摆玩具

思维好题

一开始掉进了二分的陷阱,发现看看逐个位置的差,我们要分成k段就是要取消k-1个最大的逐差

然后将剩余的加起来就可以了

因为本体保证是从小到大给出的 这一点保证了答案的正确性,自己没想出来 还是太菜了

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N = 1e6+10;
int n,k;
int w[N];
vector<int>s;
using ll = long long;
ll res;
int main()
{
	cin>>n>>k;
	for(int i=1;i<=n;i++)cin>>w[i];
	 
	for(int i=2;i<=n;i++)s.push_back(w[i]-w[i-1]);
	sort(s.begin(),s.end(),greater<>());
	
	k = k-1;
	for(auto &t:s){
		if(!k)break;
		t = 0;
		k--;
	}
	

 	for(auto t:s)
 		res+=t;
 	
 	
 	cout<<res;
}
相关推荐
sali-tec几秒前
C# 基于OpenCv的视觉工作流-章79-单位转换
图像处理·人工智能·opencv·算法·计算机视觉
兰令水1 分钟前
leecodecode【双指针题2】【2026.5.26打卡-java版本】
java·开发语言·算法
一只老丸2 分钟前
HOT100题打卡第27天——动态规划(hard)
算法·动态规划
羑悻的小杀马特2 分钟前
【动态规划篇】正则表达式与通配符:开启代码匹配的赛博奇幻之旅
c++·算法·leetcode·正则表达式
吴可可1233 分钟前
SolidWorks二次开发实战应用
算法
春日见14 分钟前
5分钟入门强化学习之蒙特卡洛(MC)算法与实现
运维·服务器·人工智能·深度学习·算法·机器学习
x_xbx15 分钟前
LeetCode:581. 最短无序连续子数组
算法·leetcode·排序算法
代码中介商22 分钟前
排序算法完全指南(八):归并排序深度详解
数据结构·算法·排序算法
kkeeper~10 小时前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
wabs66611 小时前
关于贪心算法的一些自我总结【力扣45.跳跃游戏II】【灵感来源:代码随想录】
算法·贪心算法·复盘