蓝桥杯算法心得——游戏(优先队列)

大家好,我是晴天学长,优先队列的题,式子化简非常重要,需要的小伙伴可以关注支持一下哦!后续会继续更新的。💪💪💪


1) .游戏


2) .算法思路

附近最小

1.接收数据

2.找出最小的(k的大小)

并记录下标位置

然后开始遍历用l,r表示

1.进来的要比最小值都要小(r++)

或者不变

2.当最小值的下标小于时,需要重新遍历,确定最小值(l++)


3).算法步骤

1.导入必要的包,包括BufferedReader和PriorityQueue。

2.创建一个BufferedReader对象in,用于读取输入数据。

3.创建两个PriorityQueue对象queue1和queue2,分别用于存储最小值和最大值。

4.声明变量max和min,用于存储最大值和最小值的累加和。

5.使用in.readLine()方法读取输入的第一行数据,并使用split()方法将其拆分为字符串数组strings。

6.将strings中的第一个元素转换为整数n,表示数组的长度,将第二个元素转换为整数k,表示窗口的大小。

7.创建一个长度为n的整数数组a,并使用循环将输入的整数赋值给数组a。

8.使用循环遍历数组a的前k个元素,并将它们添加到queue1和queue2中。

9.将queue1和queue2的顶部元素分别赋值给min和max。

10.使用循环遍历数组a的剩余元素:

a. 如果当前元素的下标大于i-k,表示当前元素已经不在窗口内,将其从queue1和queue2中移除。

b. 将当前元素添加到queue1和queue2中。

c. 移除queue1和queue2中下标小于i的元素。

d. 将queue1和queue2的顶部元素的值分别累加到min和max中。

11.计算(max-min)/(n-k+1)并将结果赋值给result。

12.使用System.out.format()方法将result格式化为保留两位小数的浮点数,并输出结果。


4). 代码实例

java 复制代码
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.PriorityQueue;
import java.util.Queue;

public class Main {
	static BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
	static String[] strings;

	public static void main(String[] args) throws IOException {
		PriorityQueue<int[]> queue1 = new PriorityQueue<>((o1,o2)->(o1[0]-o2[0]));
		PriorityQueue<int[]> queue2 = new PriorityQueue<>((o1,o2)->(o2[0]-o1[0]));
		long max = 0;
		long min = 0;
		strings = in.readLine().split(" ");
		int n = Integer.parseInt(strings[0]);
		int k = Integer.parseInt(strings[1]);
		int[] a= new int[n];
		strings = in.readLine().split(" ");
		for (int i = 0; i < n; i++) {
			a[i] = Integer.parseInt(strings[i]);
		}
		for (int i = 0; i < k; i++) {
			queue1.add(new int[] {a[i],i});
			queue2.add(new int[] {a[i],i});
		}
		min=queue1.peek()[0];
		max=queue2.peek()[0];
		for (int i = 1; i <= n-k; i++) {
			if (i<=n-k) {
				queue1.add(new int[] {a[i+k-1],i+k-1});
				queue2.add(new int[] {a[i+k-1],i+k-1});
			}
			while(i>queue1.peek()[1]) {
				queue1.poll();
			}
			while (i>queue2.peek()[1]) {
				queue2.poll();
			}
			min+=queue1.peek()[0];
			max+=queue2.peek()[0];
		}
		double result = (max-min)/(double)(n-k+1);
		System.out.format("%.2f", result);

	}

}

5).总结

  • 优先队列的正确使用。

试题链接:

相关推荐
DC...18 分钟前
【力控】混合位置 / 力控制
算法·机器人·力控
Rabitebla19 分钟前
归并排序(MergeSort)完全指南 —— 从原理到非递归实现
c语言·数据结构·c++·算法·排序算法
WBluuue23 分钟前
Codeforces Educational 188(ABCDEF)
c++·算法
AI成长日志27 分钟前
【笔面试算法学习专栏】双指针专题:简单难度三题精讲(167.两数之和II、283.移动零、344.反转字符串)
学习·算法·面试
Book思议-31 分钟前
【数据结构】数组与特殊矩阵
数据结构·算法·矩阵
酉鬼女又兒39 分钟前
零基础快速入门前端DOM 节点操作核心知识点及蓝桥杯 Web 应用开发考点解析(可用于备赛蓝桥杯Web应用开发)
开发语言·前端·javascript·职场和发展·蓝桥杯
不吃蘑菇!44 分钟前
LeetCode Hot 100-1(两数之和)
java·数据结构·算法·leetcode·哈希表
全栈软件开发1 小时前
vue租号系统源码/租号玩平台源码/游戏账号出租系统/虚拟账号出租平台源码
游戏·租号系统源码
paeamecium1 小时前
【PAT甲级真题】- Linked List Sorting (25)
数据结构·c++·算法·pat考试·pat
huwuhang1 小时前
PPSSPP模拟器游戏合集下载 PSP游戏资源 主题和金手指、游戏封面、PSP用PS1游戏
游戏