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

Python Discussion :

Trier des individus selon une parité sexuelle


Sujet :

Python

  1. #21
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 690
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 690
    Points : 30 986
    Points
    30 986
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par mrsogravity Voir le message
    Et si jamais il n'est pas possible de créer une classe avec une parité maximale de 4, la parité sera donc augmentée.
    Dans ce cas, autant ne pas mettre d'écart maximal et écrire une fonction qui tente de répartir "au mieux". Si 60 filles et 60 garçons alors ok sinon tant pis.
    Et là le code de MPython Alaplancha peut être utilisé comme point de départ. On sépare filles et garçons puis on les prend 2 par 2 et on remplit. Et à la fin on place ce qui reste...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  2. #22
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 287
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 287
    Points : 36 776
    Points
    36 776
    Par défaut
    Citation Envoyé par mrsogravity Voir le message
    Les contraintes sont telles que nous avons une liste d'à peu près 120 élèves et qu'il nous faut les répartir dans 4 classes.
    120 élèves se décomposent en G garçons et F filles (i.e. G+F=120).
    La division de G par 4 (classes) donne un nombre de garçons par classe #G et un reste < 4 (à répartir en ajoutant un élève dans certaines classes).
    On recommence avec les F.

    Citation Envoyé par mrsogravity Voir le message
    L'objectif est surtout de créer des classes ayant une certaine parité de sexe et en l'occurrence avec une parité qui peut être changée
    on sait répartir autant de garçons et de filles dans chaque classes.... Mais si on n'a pas de parité au départ, on ne va pas l'avoir à l'arrivée: ce truc de "parité" est un objectif politique (non technique) qu'on saura réaliser "techniquement" qu'avec un nombre de garçons plus ou moins égal au nombre de filles.

    De fait tant que vous n'avez pas un cahier des charges plus précis sur ce sujet, c'est pas la peine de se lancer à coder: on ne sait pas ce qu'on va devoir coder!

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #23
    Expert confirmé Avatar de papajoker
    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2013
    Messages
    2 105
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nièvre (Bourgogne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2013
    Messages : 2 105
    Points : 4 455
    Points
    4 455
    Par défaut
    C'est donc bien ce que je pensais, cette différence de 4 n'a pas a rentrer dans l'algo C'est juste Afficher un message si la classe dépasse cette différence désirée.

    Moi, ce qui ne confond le plus c'est le rapport nombre d'élèves/classes. Ici tu triches, c'est en fait simplement faire l'autruche ? Ou alors, l'école refuse les inscriptions si pas multiple de 30
    Dans mon code (qui fonctionne du coup), j'avais justement entré un nombre non divisible par 30 et résultat, on avait des classes de 24(de mémoire). Pour moi, le véritable travail est ici (sur la création des classes) et non le mélange des genres qui lui ne pose en fait aucun problème.

    Note:
    je me souviens de mes années collège : il y avait des classes avec allemand et des classes avec espagnol et d'autres avec latin (pas de mélange) Connu aussi une classe sport-études (en plus internat)
    je me souviens de mes années lycée : il y avait des classes internat (pas de mélange)
    $moi= ( !== ) ? : ;

  4. #24
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 690
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 690
    Points : 30 986
    Points
    30 986
    Billets dans le blog
    1
    Par défaut
    Voilà un code qui dispatche "au mieux"
    Code python : 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
    import itertools
    liste=(
    	('Jean', 'M'),
    	('Enzo', 'M'),
    	('Juliette', 'F'),
    	('Blanche', 'F'),
    	('Aurore', 'F'),
    	('Gabriel ', 'M'),
    	('Marc', 'M'),
    	('Manon', 'F'),
    	('Emma', 'F'),
    	('Ulysse', 'M'),
    	('Kevin', 'M'),
    	('Iris', 'F'),
    	('Jeremy', 'M'),
    	('Michel', 'M'),
    	('Noemie', 'F'),
    	('Axel', 'M'),
    	('Yanis', 'M'),
    	('Solene', 'F'),
    	('Alice', 'F'),
    	('Valerie', 'F'),
    	('ValerieA', 'F'),
    	('ValerieB', 'F'),
    	('ValerieC', 'F'),
    	('ValerieD', 'F'),
    )		# Pas besoin de liste quand un tuple suffit...
     
    def makeClasses(eleves, *, nb=4):
    	# Création des "nb" classes
    	classes=dict(("classe_%d" % i, list()) for i in range(1, nb+1))
     
    	# Séparation garçons/filles (on va reprendre le code de MPython Alaplancha ça lui fera plaisir ;)
    	garcons=tuple(x[0] for x in eleves if x[1] == "M")
    	filles=tuple(x[0] for x in eleves if x[1] == "F")
     
    	# Traitement des garçons et filles
    	for (i, (g, f)) in enumerate(itertools.zip_longest(garcons, filles)):
    		# Remplissage classe
    		key="classe_%d" % (i%nb + 1)
    		if g is not None: classes[key].append(g)
    		if f is not None: classes[key].append(f)
    	# for
    	return classes
    # makeClasses()
     
    classes=makeClasses(liste)
    for (k, v) in classes.items(): print(k, v)
    Il commence par prendre chaque couple garçon+fille et le dispatche dans les classes en rotatif (couple1 => classe1, couple2 => classe2, etc...).
    Ensuite il continue de la même façon avec les éléments isolés.
    Et tu remarqueras que j'ai viré toutes les contraintes parce qu'on ne peut pas avoir et à la fois 4 classes max et à la fois 30 élèves par classe et à la fois pas plus de 4 d'écart de parité. J'ai fait au plus simple: on lui donne le nb de classes et le nb d'élèves (ce qui correspond à mon avis au mieux à la réalité => une école connait son nb de classes et rien d'autre) et lui il distribue en équité.
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  5. #25
    Membre expérimenté
    Avatar de MPython Alaplancha
    Homme Profil pro
    Paysan à 3 francs six sous
    Inscrit en
    Juin 2018
    Messages
    870
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Paysan à 3 francs six sous
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Juin 2018
    Messages : 870
    Points : 1 522
    Points
    1 522
    Billets dans le blog
    4
    Par défaut
    # Séparation garçons/filles (on va reprendre le code de MPython Alaplancha ça lui fera plaisir
    En effet, rire c'est prendre du plaisir!.
    #Rien de nouveau sous le soleil, tout est vanité comme courir après le vent!
    Developpement pour Android avec Python3/Kivy/Buildozer

  6. #26
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Avril 2004
    Messages
    1 049
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 1 049
    Points : 1 380
    Points
    1 380
    Par défaut
    Alors si on laisse tomber les contraintes, suffit de diviser la liste de filles et la liste de garçons par le nombre de classes non ?

Discussions similaires

  1. [9][logiciel]Restriction des données selon une période
    Par hondavtec77 dans le forum SAP Crystal Reports
    Réponses: 3
    Dernier message: 14/09/2007, 11h42
  2. Grouper des données selon une date
    Par gids01 dans le forum iReport
    Réponses: 2
    Dernier message: 30/07/2007, 16h03
  3. [MySQL] Afficher des évènements selon une année précise
    Par gotenks dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 11/01/2006, 13h43
  4. Boucle en Dos pour lister des fichiers selon une date
    Par Corben dans le forum Autres Logiciels
    Réponses: 1
    Dernier message: 17/12/2005, 12h17
  5. Trigger vidant des informations selon une contrainte de temp
    Par jlassira dans le forum Développement
    Réponses: 1
    Dernier message: 16/11/2005, 15h50

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