Maison >développement back-end >tutoriel php >. Le plus grand nombre

. Le plus grand nombre

DDD
DDDoriginal
2024-09-19 06:21:07594parcourir

. Largest Number

179. Le plus grand nombre

Difficulté :Moyen

Sujets :Array, String, Greedy, Sorting

Étant donné une liste de nombres entiers non négatifs, disposez-les de telle sorte qu'ils forment le plus grand nombre et renvoyez-le.

Comme le résultat peut être très volumineux, vous devez donc renvoyer une chaîne au lieu d'un entier.

Exemple 1 :

  • Entrée : nums = [10,2]
  • Sortie : "210"

Exemple 2 :

  • Entrée : nums = [3,30,34,5,9]
  • Sortie : "9534330"

Contraintes :

  • 1 <= nums.length <= 100
  • 0 <= nums[i] <= 109

Solution :

Nous devons comparer les nombres en fonction de leurs résultats concaténés. Pour deux nombres a et b, nous comparons ab (a concaténé avec b) et ba (b concaténé avec a), et décidons de l'ordre en fonction duquel forme un plus grand nombre.

Approche:

  1. Tri personnalisé : implémentez une fonction de comparaison personnalisée qui trie les nombres en comparant les résultats concaténés.
  2. Edge Case : Si le plus grand nombre après le tri est 0, alors le résultat est "0", car tous les nombres doivent être nuls.
  3. Concaténation : Après le tri, concaténez les nombres pour former le résultat final.

Implémentons cette solution en PHP : 179. Le plus grand nombre






Explication:

  1. usort($nums, $comparator) : Nous trions le tableau à l'aide d'un comparateur personnalisé. Pour chaque paire de nombres a et b, nous comparons les chaînes concaténées a . b et b . une.
  2. Logique de comparaison : Le strcmp($order2, $order1) garantit que nous obtenons un ordre décroissant basé sur les chaînes concaténées.
  3. Edge Case Handling : Si le premier caractère de la chaîne concaténée résultante est 0, nous renvoyons "0", ce qui se produit lorsque tous les éléments du tableau sont des zéros.
  4. Complexité temporelle : le tri des nombres prend O(n log n), et leur concaténation prend O(n), où n est le nombre de nombres dans le tableau d'entrée.

Cette solution gère efficacement les contraintes et renvoie le plus grand nombre possible sous forme de chaîne.

Liens de contact

Si vous avez trouvé cette série utile, pensez à donner une étoile au référentiel sur GitHub ou à partager la publication sur vos réseaux sociaux préférés ?. Votre soutien signifierait beaucoup pour moi !

Si vous souhaitez du contenu plus utile comme celui-ci, n'hésitez pas à me suivre :

  • LinkedIn
  • GitHub

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn