HJ182 画展布置

  • 题目
  • 题解(13)
  • 讨论(9)
  • 排行

中等 通过率:23.96% 时间限制:1秒 空间限制:256M

知识点双指针

校招时部分企业笔试将禁止编程题跳出页面,为提前适应,练习时请使用在线自测,而非本地IDE。

描述

展厅共有 NN 幅画作,其艺术价值为整数 A1,A2,...,ANA1​,A2​,...,AN​。策展人需选出其中 MM 幅依次摆放。设选出后排成一列的价值为 B1,...,BMB1​,...,BM​,定义一个画展的不和谐度 LL 满足:

L  =  ∑i=1M−1∣Bi+12−Bi2∣.L=∑i=1M−1​∣∣​Bi+12​−Bi2​∣∣​.

请最小化 LL 并输出其最小可能值。

输入描述:

第一行输入两个整数 N,M(2≦M≦N≦105)N,M(2≦M≦N≦105)。

第二行输入 NN 个整数 A1...AN(1≦Ai≦105)A1​...AN​(1≦Ai​≦105)。

输出描述:

输出一个整数,表示最小化后的 LL 值。

示例1

输入:

复制代码
4 2
1 5 2 4

复制输出:

复制代码
3

复制说明:

复制代码
选择 {1,2}{1,2} 得到 L=22−12=3L=22−12=3,为最小值。
cpp 复制代码
#include <iostream>
#include <vector>
#include <algorithm>
#include <climits>

using namespace std;

int main() {
    int n, m;
    cin >> n >> m;
    vector<long long> a(n);
    for (int i = 0; i < n; ++i) {
        cin >> a[i];
    }

    sort(a.begin(), a.end());

    long long min_l = LLONG_MAX;

    for (int i = 0; i <= n - m; ++i) {
        long long current_l = a[i + m - 1] * a[i + m - 1] - a[i] * a[i];
        min_l = min(min_l, current_l);
    }

    cout << min_l << endl;

    return 0;
}
相关推荐
香蕉鼠片21 小时前
MFC是什么
c++·mfc
心态与习惯1 天前
Julia 初探,及与 C++,Java,Python 的比较
java·c++·python·julia·比较
py有趣1 天前
力扣热门100题之不同路径
算法·leetcode
_日拱一卒1 天前
LeetCode:25K个一组翻转链表
算法·leetcode·链表
啊哦呃咦唔鱼1 天前
LeetCodehot100-394 字符串解码
算法
小欣加油1 天前
leetcode2078 两栋颜色不同且距离最远的房子
数据结构·c++·算法·leetcode·职场和发展
我真不是小鱼1 天前
cpp刷题打卡记录30——轮转数组 & 螺旋矩阵 & 搜索二维矩阵II
数据结构·c++·算法·leetcode
南境十里·墨染春水1 天前
C++ 笔记 thread
java·开发语言·c++·笔记·学习
南境十里·墨染春水1 天前
C++ 笔记 高级线程同步原语与线程池实现
java·开发语言·c++·笔记·学习
瞎折腾啥啊1 天前
CMake FetchContent与ExternalProject
c++·cmake·cmakelists