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

API standards et tierces Java Discussion :

CHOCO solver 2.1.4


Sujet :

API standards et tierces Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Juin 2007
    Messages
    453
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 453
    Par défaut CHOCO solver 2.1.4
    Bonjour à tous

    J'utilise la programmation par contraintes pour resoudre un petit probleme, j'ai un tableau de n entier et je dois prendre les entiers qui ont une somme egale à S. exemple: t= 100, 120, 90, 200, 80, 20 et S=200
    resultat souhaité
    1) 100+20+80
    2) 200
    3) 120+80
    ...etc

    j'ai fais ce code qui n'est pas complet :

    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
    int somme = 200;
    		int[] tab = new int[] {100, 120, 90, 200, 80, 20};
     
    			Model m = new CPModel();
    			Solver s = new CPSolver();
     
                            IntegerVariable[] vars = new IntegerVariable[tab.length];
                            for (int i = 0; i < tab.length; i++) 
                                vars[i] = Choco.makeIntVar("a"+i, 0, 1);
     
     
     
                            IntegerExpressionVariable  s1 = null;
                            for (int i = 0; i < tab.length; i++)
                            {
                                s1 = Choco.plus(Choco.mult(vars[i], tab[i]), s1);
                            }
     
                            m.addConstraint(Choco.eq(s1,somme));
     
     
    			s.read(m);
    			s.solve();
    comme vous voyez, j'ai creer autant de variables que d'element ds le tableau, ces variables peuvent prendre soit 0 soit 1, selon on prend ou on prend pas, si l'entier est selectionner on met 1 sinn on met 0.

    J'ai besoin de votre aide, et merci d'avance

  2. #2
    Modérateur
    Avatar de wax78
    Homme Profil pro
    R&D - Palefrenier programmeur
    Inscrit en
    Août 2006
    Messages
    4 095
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : R&D - Palefrenier programmeur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2006
    Messages : 4 095
    Par défaut
    Je me demande si http://www.developpez.net/forums/d12...-choco-solver/ n'as pas deja ete posée
    (Les "ça ne marche pas", même écrits sans faute(s), vous porteront discrédit ad vitam æternam et malheur pendant 7 ans)

    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

Discussions similaires

  1. [Choco] Optimisation avec Solver.minimize()
    Par devhercule dans le forum API standards et tierces
    Réponses: 1
    Dernier message: 24/02/2017, 22h47
  2. minimisation choco solver
    Par devhercule dans le forum Général Java
    Réponses: 0
    Dernier message: 20/12/2012, 09h45
  3. API choco solver
    Par devhercule dans le forum API standards et tierces
    Réponses: 11
    Dernier message: 19/07/2012, 16h46

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