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;
}
相关推荐
咩咦33 分钟前
C++学习笔记02:cin 和 cout 输入输出
c++·学习笔记·cin·输入输出·cout
咩咦38 分钟前
C++学习笔记05:引用和常引用
c++·学习笔记·引用·const·常引用
香蕉鼠片1 小时前
算法过程中不会的
开发语言·c++
阿旭超级学得完1 小时前
C++11包装器(function和bind)
java·开发语言·c++·算法·哈希算法·散列表
li星野1 小时前
位运算 & 数学 & 高频进阶九题通关(Python + C++)
c++·python·学习·算法
jerryinwuhan1 小时前
hello算法,简单讲(1)
算法·排序算法
y = xⁿ1 小时前
20天速通LeetCodeday15:BFS广度优先搜索
算法·宽度优先
400分1 小时前
吃透RAG核心-----语义检索与关键字检索底层原理
算法·架构
目黑live +wacyltd1 小时前
算法备案:常见驳回原因与应对策略
人工智能·算法
磊 子2 小时前
多态类原理+四种类型转换+异常处理
开发语言·c++·算法