. Échange maximum

Oct 17, 2024 pm 10:09 PM

. Maximum Swap

670. Échange maximum

Difficulté :Moyen

Sujets : Mathématiques, gourmand

Vous recevez un nombre entier. Vous pouvez échanger deux chiffres au maximum une fois pour obtenir le nombre de valeur maximale.

Renvoyer le nombre de valeur maximale que vous pouvez obtenir.

Exemple 1 :

  • Entrée : num = 2736
  • Sortie : 7236
  • Explication : Intervertissez le chiffre 2 et le chiffre 7.

Exemple 2 :

  • Entrée : num = 9973
  • Sortie : 9973
  • Explication :Pas d'échange.

Contraintes :

  • 0 <= num <= 108

Solution :

On peut suivre une approche gourmande. Voici une explication étape par étape et la solution :

Approche:

  1. Convertir le nombre en tableau : étant donné que les chiffres doivent être échangés, la conversion du nombre en un tableau de chiffres facilite l'accès et la manipulation des chiffres individuels.
  2. Suivez l'occurrence la plus à droite de chaque chiffre : stockez la position la plus à droite de chaque chiffre (0-9) dans un tableau.
  3. Trouvez la meilleure opportunité d'échange : parcourez les chiffres du numéro de gauche à droite et pour chaque chiffre, vérifiez s'il y a un chiffre supérieur qui apparaît plus tard. Si c'est le cas, échangez-les pour maximiser le nombre.
  4. Effectuez l'échange et la rupture : Dès que l'échange optimal est trouvé, effectuez l'échange et rompez la boucle.
  5. Convertir le tableau en nombre : après l'échange, reconvertissez le tableau de chiffres en nombre et renvoyez-le.

Implémentons cette solution en PHP : 670. Échange maximum






Explication:

  • Étape 1 : strval($num) convertit l'entier en chaîne et str_split($numStr) le divise en un tableau de chiffres.
  • Étape 2 : Le dernier tableau garde la trace de l'index le plus à droite de chaque chiffre de 0 à 9.
  • Étape 3 : Nous parcourons chaque chiffre et recherchons un chiffre plus grand qui peut être échangé.
  • Étape 4 : Si un chiffre plus grand approprié est trouvé (qui apparaît plus tard dans le numéro), les chiffres sont échangés.
  • Étape 5 : Le tableau modifié est reconverti en chaîne puis en entier à l'aide de intval().

Complexité:

  • Complexité temporelle : O(n), où n est le nombre de chiffres dans num. En effet, nous effectuons un passage par le numéro pour remplir le dernier tableau et un autre passage pour trouver l'échange optimal.
  • Complexité spatiale : O(1) (en ignorant la taille d'entrée) puisque le dernier tableau est fixé avec 10 éléments.

Cette solution trouve efficacement la valeur maximale en échangeant les chiffres une seule fois, selon les besoins.

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 de ce site Web
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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

11 meilleurs scripts de raccourcissement d'URL PHP (gratuit et premium) 11 meilleurs scripts de raccourcissement d'URL PHP (gratuit et premium) Mar 03, 2025 am 10:49 AM

11 meilleurs scripts de raccourcissement d'URL PHP (gratuit et premium)

Introduction à l'API Instagram Introduction à l'API Instagram Mar 02, 2025 am 09:32 AM

Introduction à l'API Instagram

Travailler avec les données de session Flash dans Laravel Travailler avec les données de session Flash dans Laravel Mar 12, 2025 pm 05:08 PM

Travailler avec les données de session Flash dans Laravel

Construisez une application React avec un Laravel Back End: Partie 2, React Construisez une application React avec un Laravel Back End: Partie 2, React Mar 04, 2025 am 09:33 AM

Construisez une application React avec un Laravel Back End: Partie 2, React

Misque de réponse HTTP simplifié dans les tests Laravel Misque de réponse HTTP simplifié dans les tests Laravel Mar 12, 2025 pm 05:09 PM

Misque de réponse HTTP simplifié dans les tests Laravel

Curl dans PHP: Comment utiliser l'extension PHP Curl dans les API REST Curl dans PHP: Comment utiliser l'extension PHP Curl dans les API REST Mar 14, 2025 am 11:42 AM

Curl dans PHP: Comment utiliser l'extension PHP Curl dans les API REST

12 meilleurs scripts de chat PHP sur Codecanyon 12 meilleurs scripts de chat PHP sur Codecanyon Mar 13, 2025 pm 12:08 PM

12 meilleurs scripts de chat PHP sur Codecanyon

Annonce de l'enquête sur la situation en 2025 PHP Annonce de l'enquête sur la situation en 2025 PHP Mar 03, 2025 pm 04:20 PM

Annonce de l'enquête sur la situation en 2025 PHP

See all articles