蓝桥杯第1374题——锻造兵器

题目描述

小明一共有n块锻造石,第块锻造石的属性值为ai.

现在小明决定从这n块锻造石中任取两块来锻造兵器

通过周密计算,小明得出,只有当两块锻造石的属性值的差值等于C,兵器才能锻造成功

请你帮小明算算,他有多少种选取锻造石的方案可以使得锻造成功

输入描述

第一行包含两个整数n,C,其含义如题所述

接下来一行包含n个整数,分别表示a1,a2,··,an.

1 < N < 2 x 10^5,|ai| < 10^4,0 < C < 10^9

输出描述

输出共一行,包含一个整数,表示答案.

输入输出样例

6 3

8 4 5 7 7 4
5

解题思路

这个题是一道典型的双指针题,要控制快指针和慢指针所对应的数据之差为C。

首先,使用排序方法对输入数据进行排序是必要的。

然后快指针优先移动,直到快慢指针数据之差至少为C;接下来慢指针进行移动,如果不是C(就一定比C大)就往后移动,直到快慢指针之差至多为C。

到此就是一组快慢指针的移动,此时可以判断快慢指针数据之差是否为C,如果是,就对ans做更新。这题的关键是ans更新多少,我们思考后不难发现,按照题目提供的例子,两个7的石头可以与两个4的石头分别组成一组,这意味着组合数量是满足要求的两个数值的石头的个数乘积,那么我们只需要对快慢指针分别派生出一个新指针,分别向后步进进行计数即可。

下面给出代码:

java 复制代码
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.lang.reflect.Array;
import java.math.BigInteger;
import java.util.*;

public class Main {

    public static void main(String[] args) throws IOException {
        Scanner sc = new Scanner(System.in);
        BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
        String[] temp = in.readLine().split(" ");
        int n = Integer.parseInt(temp[0]);
        int c = Integer.parseInt(temp[1]);
        temp = in.readLine().split(" ");
        int[] data = new int[n];
        for (int i = 0; i < n; i++) {
            data[i] = Integer.parseInt(temp[i]);
        }
        Arrays.sort(data);

        int slow = 0, fast = 0;
        long ans = 0;
        while (fast < n) {
            while (fast < n && data[fast] - data[slow] < c) {
                fast++;
            }
            while (fast < n && data[fast] - data[slow] > c) {
                slow++;
            }

            if (fast < n && data[fast] - data[slow] == c) {
                int oldFast = fast, oldSlow = slow;
                while (fast < n && data[fast] == data[oldFast]) {
                    fast++;
                }
                while (slow < n && data[slow] == data[oldSlow]) {
                    slow++;
                }
                ans += (long) (fast - oldFast) * (slow - oldSlow);
            }
        }
        System.out.println(ans);
    }
}
相关推荐
机器学习之心7 分钟前
一区北方苍鹰算法优化+创新改进Transformer!NGO-Transformer-LSTM多变量回归预测
算法·lstm·transformer·北方苍鹰算法优化·多变量回归预测·ngo-transformer
yyt_cdeyyds18 分钟前
FIFO和LRU算法实现操作系统中主存管理
算法
alphaTao44 分钟前
LeetCode 每日一题 2024/11/18-2024/11/24
算法·leetcode
kitesxian1 小时前
Leetcode448. 找到所有数组中消失的数字(HOT100)+Leetcode139. 单词拆分(HOT100)
数据结构·算法·leetcode
VertexGeek2 小时前
Rust学习(八):异常处理和宏编程:
学习·算法·rust
石小石Orz2 小时前
Three.js + AI:AI 算法生成 3D 萤火虫飞舞效果~
javascript·人工智能·算法
jiao_mrswang2 小时前
leetcode-18-四数之和
算法·leetcode·职场和发展
qystca3 小时前
洛谷 B3637 最长上升子序列 C语言 记忆化搜索->‘正序‘dp
c语言·开发语言·算法
薯条不要番茄酱3 小时前
数据结构-8.Java. 七大排序算法(中篇)
java·开发语言·数据结构·后端·算法·排序算法·intellij-idea
今天吃饺子3 小时前
2024年SCI一区最新改进优化算法——四参数自适应生长优化器,MATLAB代码免费获取...
开发语言·算法·matlab