Sword Finger: organice la matriz en el número más pequeño: int [] a string [], ordenación personalizada

Tema Descripción

Ingrese una matriz de enteros no negativos, concatene todos los números de la matriz para formar un número e imprima el más pequeño entre todos los números que se pueden concatenar.

Entrada: [10,2]
Salida: "102"

Entrada: [3,30,34,5,9]
Salida: "3033459"

tren de pensamiento

Regla de juicio de clasificación:
sean nums dos números cualesquiera en el formato de cadena x e y, entonces
si la cadena concatenada x + y > >y+x, entonces x > y;
de lo contrario, si x + y < y + x, entonces y <x;

Ordene en orden ascendente utilizando cualquier método de clasificación.

el código

  1. Arrays.sort;
class Solution {
    
    
    public String minNumber(int[] nums) {
    
    
        String[] strs = new String[nums.length];
        for(int i = 0; i < nums.length; i++) 
            strs[i] = String.valueOf(nums[i]);
        //内置Arrays.Sort()
        Arrays.sort(strs, (x, y) -> (x + y).compareTo(y + x));
        StringBuilder res = new StringBuilder();
        for(String s : strs)
            res.append(s);
        return res.toString();
    }
}
  1. fila rápida
class Solution {
    
    
    public String minNumber(int[] nums) {
    
    
        String[] strs = new String[nums.length];
        for(int i = 0; i < nums.length; i++)
            strs[i] = String.valueOf(nums[i]);
        fastSort(strs, 0, strs.length - 1);
        StringBuilder res = new StringBuilder();
        for(String s : strs)
            res.append(s);
        return res.toString();
    }
    void fastSort(String[] strs, int l, int r) {
    
    
        if(l >= r) return;
        int i = l, j = r;
        String tmp = strs[i];
        while(i < j) {
    
    
            while((strs[j] + strs[l]).compareTo(strs[l] + strs[j]) >= 0 && i < j) j--;
            while((strs[i] + strs[l]).compareTo(strs[l] + strs[i]) <= 0 && i < j) i++;
            tmp = strs[i];
            strs[i] = strs[j];
            strs[j] = tmp;
        }
        strs[i] = strs[l];
        strs[l] = tmp;
        fastSort(strs, l, i - 1);
        fastSort(strs, i + 1, r);
    }
}

Supongo que te gusta

Origin blog.csdn.net/qq_32301683/article/details/108986134
Recomendado
Clasificación