Maison développement back-end Golang Avènement de Code n Golang : rapports de découpage en tranches et en dés

Avènement de Code n Golang : rapports de découpage en tranches et en dés

Dec 20, 2024 am 08:31 AM

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
Copier après la connexion
Copier après la connexion
  • 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
}
Copier après la connexion
Copier après la connexion

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
Copier après la connexion
Copier après la connexion

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
}
Copier après la connexion
Copier après la connexion

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

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

GO Language Pack Import: Quelle est la différence entre le soulignement et sans soulignement?

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

Comment mettre en œuvre le transfert d'informations à court terme entre les pages du cadre Beego?

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

Comment convertir la liste des résultats de la requête MySQL en une tranche de structure personnalisée dans le langage Go?

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

Comment puis-je définir des contraintes de type personnalisé pour les génériques en Go?

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

Comment écrire des objets et des talons simulés pour les tests en Go?

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

Comment rédigez-vous des tests unitaires en Go?

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

Comment écrire des fichiers dans GO Language de manière pratique?

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

Comment puis-je utiliser des outils de traçage pour comprendre le flux d'exécution de mes applications GO?

See all articles