La description de ce problème indique simplement :
Étant donné un tableau d'entiers nums, renvoie la longueur de la sous-séquence strictement croissante la plus longue.
Par exemple :
Input: nums = [10, 9, 2, 5, 3, 7, 101, 18] Output: 4 Explanation: The longest increasing subsequence is [2, 3, 7, 101], therefore the length is 4.
Ou :
Input: nums = [0, 1, 0, 3, 2, 3] Output: 4
Ou :
Input: nums = [7, 7, 7, 7, 7, 7, 7] Output: 1
Semblable au problème précédent de cette série, nous pouvons également examiner ici une approche de programmation dynamique ascendante.
Pour chaque valeur du tableau nums, la longueur de la plus grande sous-séquence que nous pouvons avoir à partir de l'index i est soit :
- 1 (cette valeur elle-même)
ou
- 1 le numéro de la plus grande sous-séquence que l'on peut avoir à partir de l'index je 1 .
Cependant, nous ne pouvons pas inclure la deuxième option si nums[i 1] est inférieur à nums[i].
Tout d'abord, nous pouvons commencer par créer un tableau dp pour contenir la longueur des sous-séquences que nous pouvons avoir à partir de chaque index de nombres. Autrement dit, dp[0] aura la longueur de la plus grande sous-séquence que nous pouvons avoir à partir de nums[0], dp[1] aura la longueur de la plus grande sous-séquence que nous pouvons avoir à partir de nums[1], et ainsi sur :
let dp = Array.from({ length: nums.length }, () => 1);
Ensuite, nous pouvons commencer à itérer à partir du dernier index de nombres vers l'arrière (car c'est la position la plus simple où il n'y a qu'une seule façon de former une sous-séquence, en prenant simplement la valeur elle-même) :
for (let i = nums.length - 1; i >= 0; i--) { /* ... */ }
Pour chaque option, nous pouvons parcourir à partir de l'index suivant pour voir si nous pouvons inclure la plus grande sous-séquence pouvant être formée à partir de cet index, si c'est le cas, nous pouvons obtenir la valeur maximale entre dp[i] et 1 dp[ j] :
for (let i = nums.length - 1; i >= 0; i--) { for (let j = i + 1; j <p>Enfin, nous pouvons renvoyer la plus grande valeur en dp :<br> </p> <pre class="brush:php;toolbar:false">function lengthOfLIS(nums: number[]): number { /* ... */ return Math.max(...dp); }
Et la solution finale ressemble à ceci :
Input: nums = [10, 9, 2, 5, 3, 7, 101, 18] Output: 4 Explanation: The longest increasing subsequence is [2, 3, 7, 101], therefore the length is 4.
Complexité temporelle et spatiale
La complexité temporelle est
O(n2)
au fur et à mesure que nous parcourons chaque élément en chiffres pour chaque élément en chiffres.
La complexité spatiale est
O(n)
car nous gardons un tableau dp et sa taille augmentera à mesure que la longueur des nombres augmente.
C'était le dernier problème de programmation dynamique de cette série. Ensuite, nous commencerons un nouveau chapitre sur les intervalles. En attendant, bon codage.
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!

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

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

L'article discute de la création, de la publication et du maintien des bibliothèques JavaScript, en se concentrant sur la planification, le développement, les tests, la documentation et les stratégies de promotion.

L'article traite des stratégies pour optimiser les performances JavaScript dans les navigateurs, en nous concentrant sur la réduction du temps d'exécution et la minimisation de l'impact sur la vitesse de chargement de la page.

Apportez des effets de film de matrice à votre page! Ceci est un plugin jQuery cool basé sur le célèbre film "The Matrix". Le plugin simule les effets de caractère vert classique dans le film, et sélectionnez simplement une image et le plugin le convertira en une image de style matrice remplie de caractères numériques. Venez et essayez, c'est très intéressant! Comment ça marche Le plugin charge l'image sur la toile et lit le pixel et les valeurs de couleur: data = ctx.getImagedata (x, y, settings.grainsize, settings.grainsize) .data Le plugin lit intelligemment la zone rectangulaire de l'image et utilise jQuery pour calculer la couleur moyenne de chaque zone. Ensuite, utilisez

L'article traite du débogage efficace de JavaScript à l'aide d'outils de développeur de navigateur, de se concentrer sur la définition des points d'arrêt, de l'utilisation de la console et d'analyser les performances.

Cet article vous guidera pour créer un carrousel d'image simple à l'aide de la bibliothèque JQuery. Nous utiliserons la bibliothèque BXSLider, qui est construite sur jQuery et offre de nombreuses options de configuration pour configurer le carrousel. De nos jours, Picture Carrousel est devenue une fonctionnalité incontournable sur le site Web - une image vaut mieux que mille mots! Après avoir décidé d'utiliser le carrousel d'image, la question suivante est de savoir comment la créer. Tout d'abord, vous devez collecter des images de haute qualité et haute résolution. Ensuite, vous devez créer un carrousel d'image en utilisant HTML et un code JavaScript. Il existe de nombreuses bibliothèques sur le Web qui peuvent vous aider à créer des carrousels de différentes manières. Nous utiliserons la bibliothèque BXSLider open source. La bibliothèque Bxslider prend en charge la conception réactive, de sorte que le carrousel construit avec cette bibliothèque peut être adapté à n'importe quel

Les ensembles de données sont extrêmement essentiels pour créer des modèles d'API et divers processus métier. C'est pourquoi l'importation et l'exportation de CSV sont une fonctionnalité souvent nécessaire. Dans ce tutoriel, vous apprendrez à télécharger et à importer un fichier CSV dans un


Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

MantisBT
Mantis est un outil Web de suivi des défauts facile à déployer, conçu pour faciliter le suivi des défauts des produits. Cela nécessite PHP, MySQL et un serveur Web. Découvrez nos services de démonstration et d'hébergement.

Listes Sec
SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.

PhpStorm version Mac
Le dernier (2018.2.1) outil de développement intégré PHP professionnel

Dreamweaver CS6
Outils de développement Web visuel

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP