最简单的难题——游戏英雄升级潜力评估

问题描述

小U在一款挂机游戏中拥有n个英雄。游戏中有一种历练升级机制,每天可以选择两个英雄进行历练,如果两位英雄的等级相同,则他们的等级都不会改变。如果英雄等级不同,那么等级较高的英雄会增加1级,而等级较低的英雄则保持不变。

小U希望至少有一个英雄能够达到2000000000000000级,他想知道有多少英雄有潜力通过历练达到这个等级。


测试样例

样例1:

输入:n = 5 ,u = [1, 2, 3, 1, 2]

输出:3

样例2:

输入:n = 4 ,u = [100000, 100000, 100000, 100000]

输出:0

样例3:

输入:n = 6 ,u = [1, 1, 1, 2, 2, 2]

输出:3

我的题解:

java 复制代码
import java.util.Arrays;

public class Main {
    public static int solution(int n, int[] u) {
        //感觉不太对的样子,找到最小的数比其高的数有多少个
        int min = Integer.MAX_VALUE;
        //找到最小值
        for(int i = 0; i < u.length; i++ ){
            min = u[i] < min ? u[i] : min;
        }
        
        //找到比其大的数有多少个
        int count = 0;
        for(int target : u){
            count += target > min ? 1 : 0; 
        }

        return count;
    }

    public static void main(String[] args) {
        System.out.println(solution(5, new int[]{1, 2, 3, 1, 2}) == 3);
        System.out.println(solution(4, new int[]{100000, 100000, 100000, 100000}) == 0);
        System.out.println(solution(6, new int[]{1, 1, 1, 2, 2, 2}) == 3);
    }
}

没问题,评级标签为难题,不理解呦......我也是做出难题的人了

相关推荐
Brookty21 分钟前
深入解析Java类加载与实例化流程
java·开发语言·学习
搂鱼11451428 分钟前
(二分、思维)洛谷 P4090 USACO17DEC Greedy Gift Takers P 题解
算法
YSRM38 分钟前
Leetcode+Java+图论+岛屿问题
java·算法·leetcode·图论
悠哉悠哉愿意1 小时前
【数据结构与算法学习笔记】双指针
数据结构·笔记·python·学习·算法
codecrafter1231 小时前
MATLAB中的while循环:从入门到精通的完整指南
java·数据库·其他·matlab
C_lea2 小时前
链表转置算法
算法·链表
未知陨落2 小时前
LeetCode:89.分割等和子集
算法·leetcode
Zz_waiting.2 小时前
Spring AOP
java·spring·代理模式·springaop
Cx330❀2 小时前
《C++ STL:vector类(下)》:攻克 C++ Vector 的迭代器失效陷阱:从源码层面详解原理与解决方案
开发语言·数据结构·c++·经验分享·算法
没有bug.的程序员2 小时前
MySQL 安全与权限管理:从基础到生产级安全实践
java·mysql·安全·adb·权限