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

C Discussion :

problème avec le backtracking(sudoku)


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Inscrit en
    Septembre 2009
    Messages
    1
    Détails du profil
    Informations forums :
    Inscription : Septembre 2009
    Messages : 1
    Par défaut problème avec le backtracking(sudoku)
    Bonjour à toutes et à tous,
    j'ai à écrire un code pour résoudre un sudoku.(en c)
    on suppose que la grille en entrée est un tableau de 9*9 chiffres entre 0 et 9 (0 pour les cases vides).
    inspirée de celle présente dans le code de i2i.fr la fonction resoudre est la suivante :

    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
    void resoudre(void)
    {
    int ligne, col, nbre, nbre_tamp;
    for (ligne = 0; ligne < size; ligne++) {
    for (col = 0; col < size; col++) {
    if (sudo[ligne][col]) continue;
    for (nbre = 1; nbre <= size; nbre++) {
    if (!verifier(ligne,col,nbre,sudo)) continue;
    nbre_tamp = sudo[ligne][col];
    sudo[ligne][col] = nbre;
    resoudre();
    if (grille_finie(sudo)) return;
    sudo[ligne][col] = nbre_tamp;
    }
    return;
    }
    }
    return;
    }
    indications:
    -la grille à resoudre est sudo
    -la fonction verifier(i,j,x,sudo) renvoie 1 s'il est possible de placer x dans sudo[i][j] et 0 sinon
    -la fonction grille_finie renvoi 1 si la grille est remplie (plus de cases vides) et 0 sinon
    -resoudre() est recursive

    voilà, quand j'execute ça ne resoud pa la grille, la grille en entrée reste la même en fin de traitement-->je ne comprends pas du tout, je bloque là

    un grand merci d'avance

  2. #2
    Expert confirmé
    Avatar de diogene
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Juin 2005
    Messages
    5 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 761
    Par défaut
    Tu aurais dû donner également le code des fonctions verifier() et grille_finie(), en fait l'intégralité du code.

    Après avoir réécrit le code de ces fonctions et avoir testé (sur un seul exemple), le code semble fonctionner et la grille de départ est bien complétée.

    Le problème est ailleurs.

Discussions similaires

  1. VC++ Direct3D8, problème avec LPD3DXFONT et LPD3DTEXTURE8
    Par Magus (Dave) dans le forum DirectX
    Réponses: 3
    Dernier message: 03/08/2002, 11h10
  2. Problème avec [b]struct[/b]
    Par Bouziane Abderraouf dans le forum CORBA
    Réponses: 2
    Dernier message: 17/07/2002, 10h25
  3. Problème avec le type 'Corba::Any_out'
    Par Steven dans le forum CORBA
    Réponses: 2
    Dernier message: 14/07/2002, 18h48
  4. Problème avec la mémoire virtuelle
    Par Anonymous dans le forum CORBA
    Réponses: 13
    Dernier message: 16/04/2002, 16h10

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