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;
}
相关推荐
一只齐刘海的猫16 小时前
【Leetcode】找到字符串中所有字母异位词
算法·leetcode·职场和发展
海清河晏11116 小时前
数据结构 | 八大排序
数据结构·算法·排序算法
Frank学习路上17 小时前
【C++】面试:关键字与语法特性
c++·面试
IronMurphy17 小时前
【算法五十七】146. LRU 缓存
算法·缓存
Irissgwe18 小时前
数据结构-栈和队列
数据结构·c++·c·栈和队列
凌波粒18 小时前
LeetCode--108.将有序数组转换为二叉搜索树(二叉树)
算法·leetcode·职场和发展
liulilittle18 小时前
KCC:在 BBR 思路上的一次探索
网络·tcp/ip·算法·bbr·通信·拥塞控制·kcc
浦信仿真大讲堂18 小时前
达索系统SIMULIA Abaqus 2026接触和约束的增强新功能介绍
人工智能·python·算法·仿真软件·达索软件
点云侠18 小时前
PCL 生成三棱锥点云
c++·算法·最小二乘法
兰令水19 小时前
leecodecode【面试150】【2026.6.13打卡-java版本】
java·算法·leetcode