Table des matières
Introduction au problème
Méthode naïve
Exemple
Complexité temporelle et spatiale
Une méthode plus efficace
Conclusion
Maison interface Web js tutoriel Programme JavaScript pour trouver les valeurs maximales et minimales dans une matrice carrée

Programme JavaScript pour trouver les valeurs maximales et minimales dans une matrice carrée

Sep 02, 2023 pm 11:21 PM

JavaScript 程序求方阵中的最大值和最小值

Pour trouver l'élément le plus grand ou le plus petit, il faut se concentrer sur le nombre de comparaisons à faire et sur la méthode à choisir pour la comparaison qui est la plus efficace : la méthode de comparaison d'éléments à l'aide d'instructions if-else ou la méthode de comparaison éléments utilisant des instructions if-else intégrées à. Nous verrons l’implémentation complète du code et son explication. Dans cet article, nous allons implémenter un programme JavaScript qui calcule les éléments les plus grands et les plus petits présents dans une matrice carrée donnée.

Introduction au problème

Cette question est simple, mais en approfondissant, vous découvrirez des concepts exceptionnels qui méritent d'être appris.

Dans ce problème, on nous donne une matrice pour laquelle nous devons trouver l'élément maximum et minimum qui y est présent. Par exemple, si la matrice est -

Mat = [ 1, 3, 7,
   5, 2, 9, 
   2, 5, 1]
Copier après la connexion

À partir de la matrice ci-dessus, nous pouvons dire que 1 est l'élément minimum ou minimum et 9 est l'élément maximum ou maximum.

Voyons comment résoudre ce problème grâce à l'implémentation du code -

Méthode naïve

Dans cette méthode, nous allons simplement parcourir tous les éléments à la fois et vérifier s'ils sont plus grands que notre élément actuel. Les étapes suivantes seront suivies -

  • Nous allons d'abord créer une fonction pour passer différentes matrices et obtenir le résultat

  • Pour une matrice donnée, nous récupérerons ses lignes et ses colonnes afin de la parcourir à l'aide d'une boucle for.

  • Nous allons créer deux variables pour stocker les éléments minimum et maximum et supposer que les éléments de la matrice sont inférieurs ou égaux à cette valeur et les initialiser à l'élément minimum 1000000000.

  • De plus, nous initialiserons l'élément maximum à -1000000000 en supposant que les éléments de la matrice sont supérieurs ou égaux à cette valeur.

  • À l'aide d'une boucle for, nous allons parcourir la matrice et pour chaque index, nous utiliserons deux conditions if-else.

  • En effectuant les comparaisons requises, nous mettrons à jour les valeurs maximales et minimales.

Exemple

// creating a function to get the minimum and maximum number
function min_max(matrix){

   // getting rows and columns of given matrix
   var rows = matrix.length
   var cols = matrix[0].length
   var min_ans = 1000000000
   var max_ans = -1000000000
   
   // traversing over the matrix
   for(var i = 0; i<rows; i++){
      for(var j = 0; j<cols; j++){
         if(min_ans > matrix[i][j]){
            min_ans = matrix[i][j];
         }
         if(max_ans < matrix[i][j]) {
            max_ans = matrix[i][j];
         }
      }
   }
   console.log("The maximum element present in the Matrix is: " + max_ans);
   console.log("The minimum element present in the Matrix is: " + min_ans);
}

// defining the matrix
Mat = [ [1, 3, 7],
[5, 2, 9],
[2, 5, 1] ]

// calling the function
min_max(Mat)
Copier après la connexion

Complexité temporelle et spatiale

La complexité temporelle du code ci-dessus est O(N*M), où N et M sont respectivement des lignes et des colonnes. De plus, la complexité spatiale est O(1).

Le problème principal ici n'est pas la complexité temporelle, mais le nombre de comparaisons que nous effectuons. Dans le code ci-dessus, nous effectuons des comparaisons N * M * 2 car pour chaque index nous vérifions les éléments minimum et maximum.

Une méthode plus efficace

Cette méthode est similaire à la méthode ci-dessus dans la plupart des cas, mais pour la partie comparaison, nous allons maintenant effectuer des comparaisons 3/2 * N* M en mettant à jour certaines instructions if-else. Regardons le code -

Exemple

// creating a function to get the minimum and maximum number
function min_max(matrix){

   // getting rows and columns of given matrix
   var rows = matrix.length
   var cols = matrix[0].length
   var min_ans = 1000000000
   var max_ans = -1000000000
   
   // traversing over the matrix
   for(var i = 0; i<rows; i++){
      for(var j = 0; j<=cols/2; j++){
         if (matrix[i][j] > matrix[i][rows - j - 1]){
            if (min_ans > matrix[i][cols - j - 1])
            min_ans = matrix[i][cols - j - 1];
            if (max_ans< matrix[i][j])
            max_ans = matrix[i][j];
         } else {
            if (min_ans > matrix[i][j])
            min_ans = matrix[i][j];
            if (max_ans < matrix[i][cols - j - 1])
            max_ans = matrix[i][cols - j - 1];
         }
      }
   }
   console.log("The maximum element present in the Matrix is: " + max_ans);
   console.log("The minimum element present in the Matrix is: " + min_ans);
}
// defining the matrix
Mat = [ [1, 3, 7],
[5, 2, 9],
[2, 5, 1] ]
// calling the function
min_max(Mat)
Copier après la connexion

Complexité temporelle et spatiale

La complexité temporelle du code ci-dessus est O(N*M), où N et M sont respectivement des lignes et des colonnes. De plus, la complexité spatiale est O(1).

Le nombre de comparaisons ici est inférieur à celui d'avant, maintenant 3/2 * (N*M).

Conclusion

Dans ce tutoriel, nous allons implémenter un programme JavaScript qui calcule les éléments maximum et minimum présents dans une matrice carrée donnée. Nous parcourons la matrice donnée et comparons chaque élément avec la variable stockant la réponse. Deux techniques sont discutées : l'une avec des comparaisons 2*N*M et l'autre avec des comparaisons 3/2*N*M, mais les deux méthodes ont la même complexité spatiale.

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
4 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)

Remplacer les caractères de chaîne en javascript Remplacer les caractères de chaîne en javascript Mar 11, 2025 am 12:07 AM

Explication détaillée de la méthode de remplacement de la chaîne JavaScript et de la FAQ Cet article explorera deux façons de remplacer les caractères de chaîne dans JavaScript: le code JavaScript interne et le HTML interne pour les pages Web. Remplacer la chaîne dans le code JavaScript Le moyen le plus direct consiste à utiliser la méthode Remplace (): str = str.replace ("trouver", "remplacer"); Cette méthode remplace uniquement la première correspondance. Pour remplacer toutes les correspondances, utilisez une expression régulière et ajoutez le drapeau global G: str = str.replace (/ fi

Tutoriel de configuration de l'API de recherche Google personnalisé Tutoriel de configuration de l'API de recherche Google personnalisé Mar 04, 2025 am 01:06 AM

Ce tutoriel vous montre comment intégrer une API de recherche Google personnalisée dans votre blog ou site Web, offrant une expérience de recherche plus raffinée que les fonctions de recherche de thème WordPress standard. C'est étonnamment facile! Vous pourrez restreindre les recherches à Y

Créez vos propres applications Web Ajax Créez vos propres applications Web Ajax Mar 09, 2025 am 12:11 AM

Vous voici donc, prêt à tout savoir sur cette chose appelée Ajax. Mais qu'est-ce que c'est exactement? Le terme Ajax fait référence à un regroupement lâche de technologies utilisées pour créer un contenu Web interactif dynamique. Le terme Ajax, inventé à l'origine par Jesse J

Exemple Couleurs Fichier JSON Exemple Couleurs Fichier JSON Mar 03, 2025 am 12:35 AM

Cette série d'articles a été réécrite à la mi-2017 avec des informations à jour et de nouveaux exemples. Dans cet exemple JSON, nous examinerons comment nous pouvons stocker des valeurs simples dans un fichier à l'aide du format JSON. En utilisant la notation de paire de valeurs clés, nous pouvons stocker n'importe quel type

10 Highlighters de syntaxe jQuery 10 Highlighters de syntaxe jQuery Mar 02, 2025 am 12:32 AM

Améliorez votre présentation de code: 10 surligneurs de syntaxe pour les développeurs Partager des extraits de code sur votre site Web ou votre blog est une pratique courante pour les développeurs. Le choix du bon surligneur de syntaxe peut améliorer considérablement la lisibilité et l'attrait visuel. T

8 Superbes plugins de mise en page JQuery Page 8 Superbes plugins de mise en page JQuery Page Mar 06, 2025 am 12:48 AM

Tirez parti de jQuery pour les dispositions de page Web sans effort: 8 plugins essentiels JQuery simplifie considérablement la mise en page de la page Web. Cet article met en évidence huit puissants plugins jQuery qui rationalisent le processus, particulièrement utile pour la création de sites Web manuels

10 tutoriels JavaScript & jQuery MVC 10 tutoriels JavaScript & jQuery MVC Mar 02, 2025 am 01:16 AM

Cet article présente une sélection organisée de plus de 10 didacticiels sur les cadres JavaScript et JQuery Model-View-Controller (MVC), parfait pour augmenter vos compétences en développement Web au cours de la nouvelle année. Ces tutoriels couvrent une gamme de sujets, de Foundatio

Qu'est-ce que & # x27; ceci & # x27; en javascript? Qu'est-ce que & # x27; ceci & # x27; en javascript? Mar 04, 2025 am 01:15 AM

Points de base Ceci dans JavaScript fait généralement référence à un objet qui "possède" la méthode, mais cela dépend de la façon dont la fonction est appelée. Lorsqu'il n'y a pas d'objet actuel, cela fait référence à l'objet global. Dans un navigateur Web, il est représenté par Window. Lorsque vous appelez une fonction, cela maintient l'objet global; mais lors de l'appel d'un constructeur d'objets ou de l'une de ses méthodes, cela fait référence à une instance de l'objet. Vous pouvez modifier le contexte de ceci en utilisant des méthodes telles que Call (), Appliquer () et Bind (). Ces méthodes appellent la fonction en utilisant la valeur et les paramètres donnés. JavaScript est un excellent langage de programmation. Il y a quelques années, cette phrase était

See all articles