• 表演评分问题


    一 问题描述

    在演讲比赛中,评委对参赛者的表演进行评分。评分方法,给定 n 个正整数评分,删除最大的 n1 个和最小的 n2 个评分,将其余评分的平均值作为参赛者的最终成绩。请给出参赛者的最终成绩。

    二 输入和输出

    1 输入

    输入包括 n 个测试用例,每个测试用例都包含两行:第 1 行包含三个整数 n1、n2 和 n。第2 行包括 n 个正整数 ai。在最后的一个测试用例后跟 3个0.

    2 输出

    对每个测试用例都单行输出参赛者的最终成绩,保留小数点后 6 位。

    三 输入和输出样例

    1 输入样例

    1 2 5

    1 2 3 4 5

    4 2 10

    2121187 902 485 531 843 582 652 926 220 155

    0 0 0

    2 输出样例

    3.500000

    562.500000

    四 算法分析和设计

    1 分析

    只需用两个队列分别存储最大的 n1 个数和最小的 n2 个数即可。

    2 设计

    定义两个优先队列,q1 最大值优先,存储最小的 n2 个数;q2 最小值优先,存储最大的 n1 个数。用总和减去这两个优先队列的元素值,然后求平均值。

    五 代码

    1. package com.platform.modules.alg.alglib.poj2833;
    2. import java.util.Comparator;
    3. import java.util.PriorityQueue;
    4. public class Poj2833 {
    5. public String output = "";
    6. class MyComparator implements Comparator {
    7. public int compare(Integer num1, Integer num2) {
    8. return num2.compareTo(num1);
    9. }
    10. }
    11. public String cal(String input) {
    12. int n1, n2, n, i, x;
    13. long sum;
    14. String[] line = input.split("\n");
    15. String[] words = line[0].split(" ");
    16. n1 = Integer.parseInt(words[0]);
    17. n2 = Integer.parseInt(words[1]);
    18. n = Integer.parseInt(words[2]);
    19. PriorityQueue q1 = new PriorityQueue<>(new MyComparator()); // 最大值优先,保存最小的 n2 个
    20. PriorityQueue q2 = new PriorityQueue<>(); // 默认为小顶堆,保存最大的 n1 个
    21. sum = 0;
    22. String[] numbers = line[1].split(" ");
    23. for (i = 0; i < n; i++) {
    24. x = Integer.parseInt(numbers[i]);
    25. sum += x;
    26. q1.add(x);
    27. q2.add(x);
    28. if (q1.size() > n2)
    29. q1.poll();
    30. if (q2.size() > n1)
    31. q2.poll();
    32. }
    33. while (!q1.isEmpty()) {
    34. sum -= q1.poll();
    35. }
    36. while (!q2.isEmpty()) {
    37. sum -= q2.poll();
    38. }
    39. output = String.format("%.6f", 1.0 * sum / (n - n1 - n2));
    40. return output;
    41. }
    42. }

    六 测试

     

  • 相关阅读:
    ArcGisRuntime100.14绘制曲线
    一、几种常用的设计模式
    ArcGIS基础:字段的别名和字段属性域设置
    CDN工作原理
    深度学习之使用Milvus向量数据库实战图搜图
    【SA8295P 源码分析 (一)】111 - 使用 Infineon 工具升级DHU 的MCU 固件过程指导
    leetcode 剑指offer 19:正则表达式匹配
    外传-Midjourney的局部重绘功能
    【概率论基础进阶】多维随机变量及其分布-两个随机变量函数Z=g(X,Y)的分布
    以太坊核心开发者建议合并的暂定日期
  • 原文地址:https://blog.csdn.net/chengqiuming/article/details/126567594