码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 力扣 1331. 数组序号转换


    题目

    给你一个整数数组 arr ,请你将数组中的每个元素替换为它们排序后的序号。

    序号代表了一个元素有多大。序号编号的规则如下:

    序号从 1 开始编号。
    一个元素越大,那么序号越大。如果两个元素相等,那么它们的序号相同。
    每个数字的序号都应该尽可能地小。

    示例

    输入:arr = [40,10,20,30]
    输出:[4,1,2,3]
    解释:40 是最大的元素。 10 是最小的元素。 20 是第二小的数字。 30 是第三小的数字。

    输入:arr = [100,100,100]
    输出:[1,1,1]
    解释:所有元素有相同的序号。

    输入:arr = [37,12,28,9,100,56,80,5,12]
    输出:[5,3,4,2,8,6,7,1,3]

    来源:力扣(LeetCode)
    链接:https://leetcode.cn/problems/rank-transform-of-an-array
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    方法1:排序+哈希表

    Java实现
    class Solution {
        public int[] arrayRankTransform(int[] arr) {
            int n = arr.length;
    
            int[] arr2 = new int[n];
            arr2 = arr.clone();
            Arrays.sort(arr2);
    
            Map<Integer, Integer> map = new HashMap<>();
            int flag = 1;
            for (int i = 0; i < n; i++) {
                if (!map.containsKey(arr2[i])) map.put(arr2[i], flag++);
            }
            
            for (int i = 0; i < n; i++) {
                arr[i] = map.get(arr[i]);
            }
            return arr;
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20

    在这里插入图片描述

  • 相关阅读:
    Java基础系列(七)——多线程
    MongoDB入门与实战-第六章-MongoDB分片
    pnpm、npm、yarn的区别
    06 Feign远程调用
    慢性子的网易,走不快的B端?
    Minimum Varied Number Codeforces 1714C
    servlet中doGet方法无法读取body中的数据
    探索生成式AI的未来:Chat与Agent的较量与融合
    latex中appendix附录怎么写
    数据结构与算法之美学习笔记:24 | 二叉树基础(下):有了如此高效的散列表,为什么还需要二叉树?
  • 原文地址:https://blog.csdn.net/qq_42467009/article/details/126034098
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号