recherche
Maisondéveloppement back-endGolangAvènement de Code n Golang : rapports de découpage en tranches et en dés

Introduction

C'est donc le deuxième jour de l'Avènement du Code 2024 à Golang, et nous allons explorer mon approche et ma solution pour la même chose. Le problème n'était pas aussi simple mais était assez simple une fois mis en œuvre et trouvé correct.

Vous pouvez consulter mes solutions ici sur GitHub.

Advent of Code n Golang: Slicing and Dicing Reports Monsieur-Destructeur / advent_of_code

L'avènement du code

Partie 1

On nous a donné quelques lignes appelées rapports, et chaque rapport comporte un certain nombre de niveaux. et l'exigence du rapport est qu'il doit être strictement croissant ou décroissant d'un facteur d'au moins 1 ou d'au plus 3.

Cela signifie que si les deux premiers éléments augmentent même d'un, les autres éléments suivants dans ce rapport devraient augmenter (de 1, 2 ou 3) niveaux, et il ne peut y avoir aucun changement (c'est-à-dire 0 changement dans deux niveaux adjacents). nombres, ou deux nombres adjacents ne peuvent pas être identiques)

7 6 4 2 1
1 2 7 8 9
9 7 6 2 1
1 3 2 4 5
8 6 4 4 1
1 3 6 7 9
  • Nous effectuons d'abord l'analyse des entrées, c'est assez simple, nous devons la diviser par n pour obtenir des rapports individuels, ce sera une chaîne donc "7 6 4 2 1", nous voulons obtenir une tranche d'entiers.

  • Nous allons donc de l'avant et divisons par espaces/espaces « » pour obtenir les niveaux individuels (nombres) et nous devons les convertir en nombres entiers.

  • Une fois que nous avons les chaînes individuelles du rapport, c'est-à-dire les niveaux tels que ["7", "6", "4", "2", "1"] , nous devons les convertir en nombres entiers.

  • Nous parcourons chacun d'eux, les convertissons en nombres entiers et les ajoutons à la liste.

  • Une fois que nous avons construit la liste, nous ajoutons à la liste des rapports qui sera le tableau de tableaux, c'est-à-dire que chaque ligne est un rapport, et chaque rapport a plusieurs niveaux donc tranche de tranche d'entiers.

func SplitLevels(lines []string) [][]int {
    reportLevels := [][]int{}
    for i, reportLine := range lines {
        reportLevels = append(reportLevels, []int{})
        for _, levelStr := range strings.Split(reportLine, " ") {
            level, err := strconv.Atoi(levelStr)
            if err != nil {
                log.Fatal(err)
            }
            reportLevels[i] = append(reportLevels[i], level)
        }
    }
    return reportLevels
}

Une fois que nous avons construit les rapports et les niveaux, nous passons à l'analyse des modèles au sein des niveaux dans les rapports individuels.

Pour ça :

  • Nous prenons d'abord des rapports individuels, calculons la différence entre les deux premiers éléments et n'oublions pas d'utiliser soigneusement la différence absolue ici.

  • Nous devons maintenir un indicateur qui indique si les niveaux dans le rapport augmentent ou diminuent, ce qui peut être déterminé avec les deux premiers éléments.

    C'est-à-dire que si les deux premiers éléments augmentent, les niveaux suivants devraient également augmenter et s'ils diminuent, alors tous les niveaux devraient également diminuer

  • Nous faisons d'abord un contrôle de garde, si la différence entre eux est de 0 ou supérieure à 3 ou inférieure à -3 ce qui est la condition des niveaux pour être en sécurité. Si tel est le cas, nous renvoyons false, c'est-à-dire que le rapport n'est pas sûr.

  • Nous parcourons maintenant le rapport après les deux premiers éléments, nous calculons ensuite la différence entre les deux niveaux suivants, si le drapeau croissant est vrai et la différence actuelle est inférieure ou égale à 0 ou si elle dépasse 3 nous le marquons également comme faux

  • L'autre condition est que si le drapeau est décroissant, ce qui signifie que les deux premiers éléments avaient une différence négative, nous vérifions donc si la différence actuelle est supérieure ou égale à 0 ou si elle est inférieure à - 3, si tel est le cas, nous marquons cela comme faux

  • Après avoir calculé la différence pour tous les niveaux, si nous sortons de la boucle, nous revenons vrai car nous n'avons vu aucune différence dans les niveaux.

7 6 4 2 1
1 2 7 8 9
9 7 6 2 1
1 3 2 4 5
8 6 4 4 1
1 3 6 7 9

Partie 2

Pour la deuxième partie, nous devons faire quelques choses, nous devons calculer si le rapport est sûr ou non, et si cela n'est pas sûr, nous pouvons presque supprimer un élément du rapport pour le rendre sûr.

Pour cela la démarche est :

  • Obtenez l'indice où nous avons vu pour la première fois l'écart dans les niveaux

  • Vérifiez en supprimant cet élément du rapport, si cela rend le rapport sûr, puis retournez vrai, c'est-à-dire que nous avons trouvé le rapport sûr

  • Si nous trouvons toujours le rapport dangereux, supprimez l'élément avant l'index où l'écart a été trouvé, si maintenant nous le trouvons sûr après avoir supprimé cet élément, alors marquez-le comme sûr

  • Si nous trouvons toujours le rapport dangereux, supprimez l'élément après l'index où nous avons initialement trouvé l'écart, si le rapport devient sûr, nous marquons ce rapport comme sûr

  • Sinon, nous marquons le rapport comme dangereux, car nous ne pouvons pas trouver uniquement l'élément amovible qui rend le rapport sûr.

func SplitLevels(lines []string) [][]int {
    reportLevels := [][]int{}
    for i, reportLine := range lines {
        reportLevels = append(reportLevels, []int{})
        for _, levelStr := range strings.Split(reportLine, " ") {
            level, err := strconv.Atoi(levelStr)
            if err != nil {
                log.Fatal(err)
            }
            reportLevels[i] = append(reportLevels[i], level)
        }
    }
    return reportLevels
}

Vous pouvez consulter mes solutions ici sur GitHub.

Advent of Code n Golang: Slicing and Dicing Reports Monsieur-Destructeur / advent_of_code

L'avènement du code

Conclusion

C'était donc ça, un problème assez simple pour le jour 2 de l'avènement du code 2024 dans Golang. J'espère que vous avez apprécié cette solution pas à pas du puzzle du premier jour de l'Avent du Code 2024 à Golang.

Faites-moi savoir si vous avez d'autres solutions intéressantes, ou si vous avez quelque chose à partager à ce sujet, tous commentaires, questions ou suggestions sont les bienvenus.

Merci d'avoir lu, et je vous verrai demain pour le jour 3

Joyeux 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!

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
GO Language Pack Import: Quelle est la différence entre le soulignement et sans soulignement?GO Language Pack Import: Quelle est la différence entre le soulignement et sans soulignement?Mar 03, 2025 pm 05:17 PM

Cet article explique les mécanismes d'importation des packages de Go: les importations nommées (par exemple, importation & quot; fmt & quot;) et les importations vierges (par exemple, importation _ & quot; fmt & quot;). Les importations nommées rendent le contenu du package accessible, tandis que les importations vierges ne font que l'exécuter t

Comment mettre en œuvre le transfert d'informations à court terme entre les pages du cadre Beego?Comment mettre en œuvre le transfert d'informations à court terme entre les pages du cadre Beego?Mar 03, 2025 pm 05:22 PM

Cet article explique la fonction Newflash () de Beego pour le transfert de données inter-pages dans les applications Web. Il se concentre sur l'utilisation de NewFlash () pour afficher les messages temporaires (succès, erreur, avertissement) entre les contrôleurs, en tirant parti du mécanisme de session. Limiter

Comment convertir la liste des résultats de la requête MySQL en une tranche de structure personnalisée dans le langage Go?Comment convertir la liste des résultats de la requête MySQL en une tranche de structure personnalisée dans le langage Go?Mar 03, 2025 pm 05:18 PM

Cet article détaille la conversion efficace de la requête MySQL Resulte en tranches de structure GO. Il met l'accent sur l'utilisation de la méthode de numérisation de la base de données / SQL pour des performances optimales, en évitant l'analyse manuelle. Meilleures pratiques pour la cartographie des champs struct à l'aide de balises DB et de robus

Comment écrire des objets et des talons simulés pour les tests en Go?Comment écrire des objets et des talons simulés pour les tests en Go?Mar 10, 2025 pm 05:38 PM

Cet article montre la création de simulations et de talons dans GO pour les tests unitaires. Il met l'accent sur l'utilisation des interfaces, fournit des exemples d'implémentations simulées et discute des meilleures pratiques telles que la tenue de simulations concentrées et l'utilisation de bibliothèques d'assertion. L'articl

Comment puis-je définir des contraintes de type personnalisé pour les génériques en Go?Comment puis-je définir des contraintes de type personnalisé pour les génériques en Go?Mar 10, 2025 pm 03:20 PM

Cet article explore les contraintes de type personnalisé de Go pour les génériques. Il détaille comment les interfaces définissent les exigences de type minimum pour les fonctions génériques, améliorant la sécurité du type et la réutilisabilité du code. L'article discute également des limitations et des meilleures pratiques

Comment écrire des fichiers dans GO Language de manière pratique?Comment écrire des fichiers dans GO Language de manière pratique?Mar 03, 2025 pm 05:15 PM

Cet article détaille la rédaction de fichiers efficace dans GO, en comparant OS.WriteFile (adapté aux petits fichiers) avec OS.OpenFile et Buffered Writes (optimal pour les fichiers volumineux). Il met l'accent sur la gestion robuste des erreurs, l'utilisation de différer et la vérification des erreurs spécifiques.

Comment rédigez-vous des tests unitaires en Go?Comment rédigez-vous des tests unitaires en Go?Mar 21, 2025 pm 06:34 PM

L'article traite des tests d'unité d'écriture dans GO, couvrant les meilleures pratiques, des techniques de moquerie et des outils pour une gestion efficace des tests.

Comment puis-je utiliser des outils de traçage pour comprendre le flux d'exécution de mes applications GO?Comment puis-je utiliser des outils de traçage pour comprendre le flux d'exécution de mes applications GO?Mar 10, 2025 pm 05:36 PM

Cet article explore l'utilisation d'outils de traçage pour analyser le flux d'exécution des applications GO. Il traite des techniques d'instrumentation manuelles et automatiques, de comparaison d'outils comme Jaeger, Zipkin et OpenTelelemetry, et mettant en évidence une visualisation efficace des données

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)
2 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
1 Il y a quelques moisBy尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
4 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

mPDF

mPDF

mPDF est une bibliothèque PHP qui peut générer des fichiers PDF à partir de HTML encodé en UTF-8. L'auteur original, Ian Back, a écrit mPDF pour générer des fichiers PDF « à la volée » depuis son site Web et gérer différentes langues. Il est plus lent et produit des fichiers plus volumineux lors de l'utilisation de polices Unicode que les scripts originaux comme HTML2FPDF, mais prend en charge les styles CSS, etc. et présente de nombreuses améliorations. Prend en charge presque toutes les langues, y compris RTL (arabe et hébreu) ​​et CJK (chinois, japonais et coréen). Prend en charge les éléments imbriqués au niveau du bloc (tels que P, DIV),

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.

SublimeText3 version anglaise

SublimeText3 version anglaise

Recommandé : version Win, prend en charge les invites de code !

Listes Sec

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.

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser