zoukankan      html  css  js  c++  java
  • Java实现 LeetCode 506 相对名次

    506. 相对名次

    给出 N 名运动员的成绩,找出他们的相对名次并授予前三名对应的奖牌。前三名运动员将会被分别授予 “金牌”,“银牌” 和“ 铜牌”(“Gold Medal”, “Silver Medal”, “Bronze Medal”)。

    (注:分数越高的选手,排名越靠前。)

    示例 1:

    输入: [5, 4, 3, 2, 1]
    输出: [“Gold Medal”, “Silver Medal”, “Bronze Medal”, “4”, “5”]
    解释: 前三名运动员的成绩为前三高的,因此将会分别被授予 “金牌”,“银牌”和“铜牌” (“Gold Medal”, “Silver Medal” and “Bronze Medal”).
    余下的两名运动员,我们只需要通过他们的成绩计算将其相对名次即可。
    提示:

    N 是一个正整数并且不会超过 10000。
    所有运动员的成绩都不相同。

    class Solution {
         public String[] findRelativeRanks(int[] nums) {
            int len = nums.length;
            String[] result = new String[len];
            if (len<1)return result;
            //1、可以把数组转换成键值对(下标:成绩)按成绩排序,最后取出对应名次
            //2、分数总量不大,不超过10000,可以用计数排序
            int min = 0;
              for (int num : nums) {
                min = num>min?num:min;
            }
            int[] map = new int[min+1];
            for (int num : nums) {
                map[num]++;
            }
            //把map中每个分数对应的人数,转换成对应名次
            int rank = 1;int temp = 0;
            for (int i = min; i >= 0; i--) {
                if (map[i]!=0){
                    temp = map[i];
                    map[i] = rank;
                    rank += temp;
                }
            }
            //把名次映射成金银铜奖"Gold Medal", "Silver Medal", "Bronze Medal"
            String s = "";int value = 0;
            for (int i = 0; i < len; i++) {
                 value= map[nums[i]];
                switch (value){
                    case 1: s = "Gold Medal";break;
                    case 2: s = "Silver Medal";break;
                    case 3: s = "Bronze Medal";break;
                    default: s = String.valueOf(value);
                }
                result[i] = s;
            }
            return result;
        }
    }
    
  • 相关阅读:
    [ICPC2016上海F] Mr. Panda and Fantastic Beasts
    [ICPC2016上海E] Bet
    [ICPC2016上海D] Ice Cream Tower
    [ICPC2016上海L] World Cup
    [CCPC2020长春F] Strange Memory
    [CF1495C] Garden of the Sun
    【实战】牛年的第一个SQL注入漏洞
    【实战】一次有趣的HPP绕WAF记录
    [模板]二分答案
    字典树及其应用
  • 原文地址:https://www.cnblogs.com/a1439775520/p/13074994.html
Copyright © 2011-2022 走看看