IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

VB.NET Discussion :

Résolution de sudoku


Sujet :

VB.NET

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    19
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 19
    Par défaut Résolution de sudoku
    Bonjour à tous,

    Je suis en train de faire un algo pour résoudre une grille de sudoku. Le principe est assez simple : on recherche les cases où on peut avoir qu'une seul solution et on la remplie, et ainsi de suite jusqu'à qu'on est tous remplis.

    Je vous fait part de mon code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    'Vérification de l'existant
    Private Function chiffreExiste(ByVal NoLigne As Integer, ByVal NoCol As Integer, ByVal number As Integer) As Boolean
    	Dim i As Integer 'Ligne de 1 à 9, soit 0 à 8 pour le tableau
    	Dim j As Integer 'Colonne de 1 à 9, soit 0 à 8 pour le tableau
    	Dim startCol As Integer
    	Dim startLigne As Integer
     
    	'Recherche sur la ligne
    	For j = 0 To 8
    		If (GrilleSolution((NoLigne - 1), j) = number) Then
    			Return True
    		End If
    	Next
     
    	'Recherche sur la colonne
    	For i = 0 To 8
    		If (GrilleSolution(i, (NoCol - 1)) = number) Then
    			Return True
    		End If
    	Next
     
    	'Recherche dans le carré
    	If (NoCol > 0 And NoCol < 4) Then
    		startCol = 0
    	Else
    		If (NoCol > 3 And NoCol < 6) Then
    			startCol = 3
    		Else
    			startCol = 6
    		End If
    	End If
     
    	If (NoLigne > 0 And NoLigne < 4) Then
    		startLigne = 0
    	Else
    		If (NoLigne > 3 And NoLigne < 6) Then
    			startLigne = 3
    		Else
    			startLigne = 6
    		End If
    	End If
     
    	For i = startLigne To (startLigne + 2)
    		For j = startCol To (startCol + 2)
    			If (GrilleSolution(i, j) = number) Then
    				Return True
    			End If
    		Next
    	Next
     
    	Return False
    End Function
     
    'Résolution de la grille de facon récursive
    Private Sub getPossibilite()
    	Dim i As Integer 'Ligne de 1 à 9, soit 0 à 8 pour le tableau
    	Dim j As Integer 'Colonne de 1 à 9, soit 0 à 8 pour le tableau
    	Dim num As Integer
    	Dim onlyOne As Boolean
     
    	onlyOne = False
     
    	For i = 1 To 9
    		For j = 1 To 9
    			GrillePossible((i - 1), (j - 1)) = ""
     
    			For num = 1 To 9
    				If (Not chiffreExiste(i, j, num)) Then
    					If (GrilleSolution((i - 1), (j - 1)) = 0) Then
    						GrillePossible((i - 1), (j - 1)) = GrillePossible((i - 1), (j - 1)) & CStr(num)
    					End If
    				End If
    			Next
    		Next
    	Next
     
    	For i = 1 To 9
    		For j = 1 To 9
    			Debug.Print(i & "/" & j & " : " & GrillePossible((i - 1), (j - 1)))
    			If (Len(GrillePossible((i - 1), (j - 1))) = 1) Then
    				Me.Controls.Find("TxtCase" & i & "_" & j, True)(0).Text = CInt(GrillePossible((i - 1), (j - 1)))
    				GrilleSolution((i - 1), (j - 1)) = CInt(GrillePossible((i - 1), (j - 1)))
    				onlyOne = True
    			End If
    		Next
    	Next
     
    	If (onlyOne) Then
    		Call getPossibilite()
    	End If
    End Sub
    Le problème c'est que les chiffres après le deuxième appel de la procédure ne correspondent plus à la solution que doit avoir la grille.


    Merci beaucoup.

  2. #2
    Membre chevronné
    Inscrit en
    Décembre 2008
    Messages
    256
    Détails du profil
    Informations personnelles :
    Âge : 48

    Informations forums :
    Inscription : Décembre 2008
    Messages : 256
    Par défaut
    Citation Envoyé par Xen3r0 Voir le message
    Le problème c'est que les chiffres après le deuxième appel de la procédure ne correspondent plus à la solution que doit avoir la grille.
    Ben y'a 3 possiblités:
    1. Ton algo est mauvais
    2. L'implémentation de ton algo est mauvaise
    3. Mauvaise implémentation d'un mauvais algorithme (1 + 2)

    Bon courage!!

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    19
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 19
    Par défaut
    Merci j'ai trouvé mon erreur, elle se situé au niveau de la vérification des ma case dans existeChiffre.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Résolution de sudoku
    Par Jonathan80 dans le forum Débuter avec Java
    Réponses: 0
    Dernier message: 25/03/2010, 20h08
  2. Projet résolution de Sudoku !
    Par Lenou dans le forum Débuter
    Réponses: 2
    Dernier message: 02/12/2009, 16h55
  3. [Java] Résolution de Sudoku par backtracking
    Par pseudocode dans le forum Contribuez
    Réponses: 1
    Dernier message: 04/01/2009, 12h58
  4. Algorithme de résolution du sudoku
    Par gnouz dans le forum Algorithmes et structures de données
    Réponses: 4
    Dernier message: 13/08/2008, 00h03
  5. Algorithme de résolution du sudoku
    Par F0ul dans le forum Débuter
    Réponses: 4
    Dernier message: 15/04/2008, 22h24

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo