首页 > 其他分享 >1636. 按照频率将数组升序排序【模拟】

1636. 按照频率将数组升序排序【模拟】

时间:2022-09-19 09:33:21浏览次数:86  
标签:1636 nums int freqs 数组 升序 100 排序

题目

给你一个整数数组 nums ,请你将数组按照每个值的频率 升序 排序。如果有多个值的频率相同,请你按照数值本身将它们 降序 排序。

请你返回排序后的数组。

难度:简单

提示:

  • 1 <= nums.length <= 100
  • -100 <= nums[i] <= 100

题解

按照题意,统计词频,再按词频排序即可。

注意在Java中是不支持对基本类型的数组自定义排序的,所以,这里我们需要要用Integer[] 数组。

class Solution {
    public int[] frequencySort(int[] nums) {
        Integer[] arr = new Integer[nums.length];
        int[] freqs = new int[201];
        for (int i = 0; i < nums.length; i++) {
            // 统计频次
            freqs[nums[i] + 100]++;
            //将int数组转换成Integer数组
            arr[i] = nums[i];
        }
        // Java中不支持对基本类型的数组自定义排序
        Arrays.sort(arr, (a, b) -> {
            // 按照频次排序
            return freqs[a + 100] == freqs[b + 100] ? b - a : freqs[a + 100] - freqs[b + 100];
            
            // 如果两个数的频次相同,那么这两个数就按照从大到小排序(后者减去前者)
            // 频次不相同,则按照频次排序
        });
        // 转换为int数组
        for (int i = 0; i < nums.length; i++) {
            nums[i] = arr[i];
        }
        return nums;
    }
}

复杂度分析

  • 时间复杂度:O(n)
  • 空间复杂度:O(n+C)

标签:1636,nums,int,freqs,数组,升序,100,排序
From: https://www.cnblogs.com/tothk/p/16706641.html

相关文章

  • 034每个进程占用内存排序
    一、  #ps-aux|head-n2  USERPID%CPU%MEMVSZRSSTTYSTATSTARTTIMECOMMAND  root10.00.019633213704?......
  • [算法]循环排序
    这类题的特点是给定的数值和下表rank是类似的,其中可能会有一些差异.在设计算法的时候,可以将value值映射到rank上去.其中,选择大于的值最好比rank的最大值+1,这样会避......
  • 1636. 按照频率将数组升序排序
    1636.按照频率将数组升序排序给你一个整数数组 nums ,请你将数组按照每个值的频率升序排序。如果有多个值的频率相同,请你按照数值本身将它们降序排序。 请你返......
  • 选择排序
    有五个数12,-1,66,5,7,选出最大的的数的下标,把最大的数与最后的位置交换,5个数找4次最大的数即可代码如下  1#include<stdio.h>2#include<math.h>3intmain()......
  • 冒泡降序排序
    假设有5个数12,-1,66,5,7解:存进一个长度为5的数组,依次比较前后两项,前<后即可交换代码如下  1#include<stdio.h>2intmain(){3inta[5]={12,-1,66,5,7};4......
  • 排序的模板
    只是按照理论搞了一下,连变量名都懒得开全,我相信他过不了编译,所以不保证正确性,不过可以表示各种排序算法的大概原理?**code#include<bits/stdc++.h>usingnamespacest......
  • Day_1(并查集朋友圈、字典序排序)
    1.并查集朋友圈:找出最多的一个圈子内有多少用户!id[](表示当前节点的父节点)nodeNum[](表示当前节点为根的那一组节点数量)importjava.util.Scanner;//并查集class......
  • map遍历、map排序
    //map遍历Map<Integer,Integer>map=newHashMap<Integer,Integer>();map.put(1,2);//1.entrySet遍历,在键和值都需要时使用(最常用)......
  • 【笔记】拓扑排序(Ⅱ)
    题单0X00P7860[COCI2015-2016#2]ARTUR好题。首先考虑本题与拓扑排序有和关系。可以想到,某些棍子的先后移动顺序是有限制的。比如:这里红色的必须比蓝色的先移动,因为......
  • js计数排序
    **计数排序**核心思想:找到数组中的最大数和最小数来确定生成数组的大小,根据数组值找到到数组下标与值相同的位置+1,来标识当前值有几个,最后遍历当前数组。letarr=[......