recherche
Maisondéveloppement back-endtutoriel phpDistance la plus courte après les requêtes d'ajout de route I

3243. Distance la plus courte après les requêtes d'ajout de route I

Difficulté :Moyen

Sujets : Tableau, recherche en largeur d'abord, graphique

Vous recevez des requêtes sur un n entier et un tableau d'entiers 2D.

Il y a n villes numérotées de 0 à n - 1. Initialement, il existe une route unidirectionnelle de la ville i à la ville i 1 pour tous 0

queries[i] = [ui, vi] représente l'ajout d'une nouvelle route unidirectionnelle depuis la ville ui à la ville vi. Après chaque requête, vous devez trouver la longueur du chemin le plus court de la ville 0 à la ville n - 1.

Renvoyer une réponse de tableau où pour chaque i dans la plage [0, queries.length - 1], la réponse[i] est la longueur du chemin le plus court de la ville 0 à la ville n - 1 après avoir traité le premieri 1 requêtes.

Exemple 1 :

  • Entrée : n = 5, requêtes = [[2,4],[0,2],[0,4]]
  • Sortie : [3,2,1]
  • Explication : Shortest Distance After Road Addition Queries I Après avoir ajouté la route de 2 à 4, la longueur du chemin le plus court de 0 à 4 est 3. Shortest Distance After Road Addition Queries I Après addition de la route de 0 à 2, la longueur du chemin le plus court de 0 à 4 est 2. Shortest Distance After Road Addition Queries I Après l'ajout de la route de 0 à 4, la longueur du chemin le plus court de 0 à 4 est 1.

Exemple 2 :

  • Entrée : n = 4, requêtes = [[0,3],[0,2]]
  • Sortie : [1,1]
  • Explication : Shortest Distance After Road Addition Queries I Après addition de la route de 0 à 3, la longueur du chemin le plus court de 0 à 3 est 1. Shortest Distance After Road Addition Queries I Après l'ajout de la route de 0 à 2, la longueur du chemin le plus court reste 1.

Contraintes :

  • 3
  • 1
  • requêtes[i].length == 2
  • 0
  • 1
  • Il n'y a pas de routes répétées parmi les requêtes.

Indice :

  1. Maintenez le graphique et utilisez un algorithme de chemin le plus court efficace après chaque mise à jour.
  2. Nous utilisons BFS/Dijkstra pour chaque requête.

Solution :

Nous devons simuler l'ajout de routes entre les villes et calculer le chemin le plus court de la ville 0 à la ville n - 1 après chaque ajout de route. Compte tenu des contraintes et de la nature du problème, nous pouvons utiliser la Breadth-First Search (BFS) pour les graphiques non pondérés.

Approche:

  1. Représentation graphique :

    • Nous pouvons représenter les villes et les routes à l'aide d'une liste de contiguïté. Initialement, chaque ville i aura une route vers la ville i 1 pour tous 0
    • Après chaque requête, nous ajoutons la route de u_i à v_i dans le graphique.
  2. Calcul du chemin le plus court (BFS) :

    • Nous pouvons utiliser BFS pour calculer le chemin le plus court de la ville 0 à la ville n - 1. BFS fonctionne bien ici car toutes les routes ont le même poids (chaque route a une longueur de 1).
  3. Itération sur les requêtes :

    • Pour chaque requête, nous ajouterons la nouvelle route au graphique, puis utiliserons BFS pour trouver le chemin le plus court de la ville 0 à la ville n - 1. Après avoir traité chaque requête, nous stockons le résultat dans le tableau de sortie.
  4. Efficacité :

    • Puisque nous utilisons BFS après chaque requête et que la taille du graphique peut être d'au plus 500 villes avec jusqu'à 500 requêtes, la complexité temporelle pour chaque BFS est O(n m), où n est le nombre de villes et m est le nombre de routes. Nous devons exécuter BFS jusqu'à 500 fois pour que la solution fonctionne efficacement dans les limites du problème.

Implémentons cette solution en PHP : 3243. Distance la plus courte après les requêtes d'ajout de route I

<?php /**
 * @param Integer $n
 * @param Integer[][] $queries
 * @return Integer[]
 */
function shortestDistanceAfterQueries($n, $queries) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

/**
 * Function to find the shortest path using BFS
 *
 * @param $graph
 * @param $n
 * @return int
 */
function bfs($graph, $n) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

// Example 1
$n = 5;
$queries = [[2, 4], [0, 2], [0, 4]];
print_r(shortestDistanceAfterQueries($n, $queries));

// Example 2
$n = 4;
$queries = [[0, 3], [0, 2]];
print_r(shortestDistanceAfterQueries($n, $queries));
?>

Explication:

  1. Initialisation du graphique :

    • Un graphique de liste de contiguïté est utilisé pour représenter les villes et les routes.
    • Au départ, les routes n'existent qu'entre des villes consécutives (i à i 1).
  2. Fonction BFS :

    • BFS est utilisé pour calculer la distance la plus courte entre la ville 0 et la ville n - 1. Nous maintenons une file d'attente pour BFS et un tableau de distances pour stocker le nombre minimum de routes (bords) pour atteindre chaque ville.
    • Initialement, la distance jusqu'à la ville 0 est définie sur 0, et toutes les autres villes ont une distance infinie (PHP_INT_MAX).
    • Au fur et à mesure que nous traitons chaque ville dans la file d'attente BFS, nous mettons à jour les distances de ses villes voisines et continuons jusqu'à ce que toutes les villes accessibles soient visitées.
  3. Traitement des requêtes :

    • Pour chaque requête, la nouvelle route est ajoutée au graphique (u -> v).
    • BFS est appelé pour calculer le chemin le plus court de la ville 0 à la ville n-1 après la mise à jour.
    • Le résultat de BFS est stocké dans le tableau de résultats.
  4. Sortie :

    • Le tableau de résultats contient les chemins les plus courts après chaque requête.
  5. Complexité temporelle :

    • Chaque BFS prend O(n m), où n est le nombre de villes et m est le nombre de routes. Puisque le nombre de requêtes est q, la complexité temporelle globale est O(q * (n m)), ce qui devrait être efficace pour les contraintes données.

Exemple de procédure pas à pas :

Pour l'entrée n = 5 et les requêtes = [[2, 4], [0, 2], [0, 4]] :

  • Au départ, les routes sont [0 -> 1 -> 2 -> 3 -> 4].
  • Après la première requête [2, 4], les routes sont [0 -> 1 -> 2 -> 3 -> 4] et le chemin le plus court de 0 à 4 est 3 (en utilisant le chemin 0 -> 1 -> 2 -> 4).
  • Après la deuxième requête [0, 2], les routes sont [0 -> 2, 1 -> 2 -> 3 -> 4], et le chemin le plus court de 0 à 4 est 2 (en utilisant le chemin 0 -> 2 -> 4).
  • Après la troisième requête [0, 4], les routes sont [0 -> 2, 1 -> 2 -> 3 -> 4], et le chemin le plus court de 0 à 4 est 1 (route directe 0 -> 4).

Ainsi, la sortie est [3, 2, 1].

Réflexions finales :

  • La solution utilise BFS pour chaque requête afin de calculer efficacement le chemin le plus court.
  • Le graphique est mis à jour dynamiquement à mesure que de nouvelles routes sont ajoutées à chaque requête.
  • La solution fonctionne bien dans les contraintes du problème et traite efficacement jusqu'à 500 requêtes avec jusqu'à 500 villes.

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
Statut actuel de PHP: un regard sur les tendances de développement WebStatut actuel de PHP: un regard sur les tendances de développement WebApr 13, 2025 am 12:20 AM

Le PHP reste important dans le développement Web moderne, en particulier dans la gestion de contenu et les plateformes de commerce électronique. 1) PHP a un écosystème riche et un fort soutien-cadre, tels que Laravel et Symfony. 2) L'optimisation des performances peut être obtenue via Opcache et Nginx. 3) PHP8.0 introduit le compilateur JIT pour améliorer les performances. 4) Les applications natives dans le cloud sont déployées via Docker et Kubernetes pour améliorer la flexibilité et l'évolutivité.

PHP vs autres langues: une comparaisonPHP vs autres langues: une comparaisonApr 13, 2025 am 12:19 AM

PHP convient au développement Web, en particulier dans le développement rapide et le traitement du contenu dynamique, mais n'est pas bon dans les applications de la science des données et de l'entreprise. Par rapport à Python, PHP présente plus d'avantages dans le développement Web, mais n'est pas aussi bon que Python dans le domaine de la science des données; Par rapport à Java, PHP fonctionne moins bien dans les applications au niveau de l'entreprise, mais est plus flexible dans le développement Web; Par rapport à JavaScript, PHP est plus concis dans le développement back-end, mais n'est pas aussi bon que JavaScript dans le développement frontal.

PHP vs Python: fonctionnalités et fonctionnalités de basePHP vs Python: fonctionnalités et fonctionnalités de baseApr 13, 2025 am 12:16 AM

PHP et Python ont chacun leurs propres avantages et conviennent à différents scénarios. 1.PHP convient au développement Web et fournit des serveurs Web intégrés et des bibliothèques de fonctions riches. 2. Python convient à la science des données et à l'apprentissage automatique, avec une syntaxe concise et une bibliothèque standard puissante. Lors du choix, il doit être décidé en fonction des exigences du projet.

PHP: un langage clé pour le développement WebPHP: un langage clé pour le développement WebApr 13, 2025 am 12:08 AM

PHP est un langage de script largement utilisé du côté du serveur, particulièrement adapté au développement Web. 1.Php peut intégrer HTML, traiter les demandes et réponses HTTP et prend en charge une variété de bases de données. 2.PHP est utilisé pour générer du contenu Web dynamique, des données de formulaire de traitement, des bases de données d'accès, etc., avec un support communautaire solide et des ressources open source. 3. PHP est une langue interprétée, et le processus d'exécution comprend l'analyse lexicale, l'analyse grammaticale, la compilation et l'exécution. 4.PHP peut être combiné avec MySQL pour les applications avancées telles que les systèmes d'enregistrement des utilisateurs. 5. Lors du débogage de PHP, vous pouvez utiliser des fonctions telles que error_reportting () et var_dump (). 6. Optimiser le code PHP pour utiliser les mécanismes de mise en cache, optimiser les requêtes de base de données et utiliser des fonctions intégrées. 7

PHP: la fondation de nombreux sites WebPHP: la fondation de nombreux sites WebApr 13, 2025 am 12:07 AM

Les raisons pour lesquelles PHP est la pile technologique préférée pour de nombreux sites Web incluent sa facilité d'utilisation, son soutien communautaire solide et son utilisation généralisée. 1) Facile à apprendre et à utiliser, adapté aux débutants. 2) Avoir une énorme communauté de développeurs et des ressources riches. 3) Largement utilisé dans WordPress, Drupal et d'autres plateformes. 4) Intégrez étroitement aux serveurs Web pour simplifier le déploiement du développement.

Au-delà du battage médiatique: évaluer le rôle de PHP aujourd'huiAu-delà du battage médiatique: évaluer le rôle de PHP aujourd'huiApr 12, 2025 am 12:17 AM

PHP reste un outil puissant et largement utilisé dans la programmation moderne, en particulier dans le domaine du développement Web. 1) PHP est facile à utiliser et intégré de manière transparente aux bases de données, et est le premier choix pour de nombreux développeurs. 2) Il prend en charge la génération de contenu dynamique et la programmation orientée objet, adaptée à la création et à la maintenance des sites Web rapidement. 3) Les performances de PHP peuvent être améliorées en mettant en cache et en optimisant les requêtes de base de données, et sa vaste communauté et son écosystème riche le rendent toujours important dans la pile technologique d'aujourd'hui.

Quelles sont les références faibles en PHP et quand sont-elles utiles?Quelles sont les références faibles en PHP et quand sont-elles utiles?Apr 12, 2025 am 12:13 AM

En PHP, les références faibles sont mises en œuvre via la classe FaibleRreference et n'empêcheront pas le collecteur des ordures de récupérer des objets. Les références faibles conviennent aux scénarios tels que les systèmes de mise en cache et les auditeurs d'événements. Il convient de noter qu'il ne peut garantir la survie des objets et que la collecte des ordures peut être retardée.

Expliquez la méthode magique __invoke en PHP.Expliquez la méthode magique __invoke en PHP.Apr 12, 2025 am 12:07 AM

La méthode \ _ \ _ Invoke permet aux objets d'être appelés comme des fonctions. 1. Définissez la méthode \ _ \ _ Invoquer afin que l'objet puisse être appelé. 2. Lorsque vous utilisez la syntaxe $ obj (...), PHP exécutera la méthode \ _ \ _ Invoke. 3. Convient pour des scénarios tels que la journalisation et la calculatrice, l'amélioration de la flexibilité et de la lisibilité du code.

See all articles

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)
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
4 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

DVWA

DVWA

Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel

VSCode Windows 64 bits Télécharger

VSCode Windows 64 bits Télécharger

Un éditeur IDE gratuit et puissant lancé par Microsoft

MinGW - GNU minimaliste pour Windows

MinGW - GNU minimaliste pour Windows

Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Puissant environnement de développement intégré PHP

Version Mac de WebStorm

Version Mac de WebStorm

Outils de développement JavaScript utiles