篮桥云课-摆玩具

思维好题

一开始掉进了二分的陷阱,发现看看逐个位置的差,我们要分成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;
}
相关推荐
qq_334903153 分钟前
编译器内建函数使用
开发语言·c++·算法
阿贵---6 分钟前
C++中的中介者模式
开发语言·c++·算法
XiaoYu1__7 分钟前
算法笔记·其一:从递归到回溯——以全排列与N皇后问题为例
c++·笔记·算法·深度优先遍历
图图的点云库9 分钟前
随机采样一致性算法实现
人工智能·算法·机器学习
_饭团17 分钟前
指针核心知识:5篇系统梳理4
c语言·开发语言·c++·笔记·深度学习·算法·面试
YXXY31325 分钟前
二分查找算法
算法
爱玩亚索的程序员25 分钟前
算法入门(一)Python基础(list、dict、set、tuple、for、enumerate、lambda、sorted)
python·算法·list
一叶落43826 分钟前
LeetCode 134. 加油站(贪心算法详解 + C语言实现)
c语言·数据结构·算法·leetcode·贪心算法
say_fall27 分钟前
位运算底层逻辑与解题应用绪论
c++·学习·算法·leetcode·职场和发展
Σίσυφος190031 分钟前
为什么 Generalized ICP(GICP)通常比 Point-to-Plane 更稳定?
算法