Option informatique
T
MP
CONCOURS CENTRALE-SUPÉLEC 4 heures Calculatrice autorisée
2020
Un système de vote
Le seul langage de programmation autorisé dans cette épreuve est Caml.
Toutes les fonctions des modules Array et List, ainsi que les fonctions de la
librairie standard (celles qui
s'écrivent sans nom de module, comme max ou incr ainsi que les opérateurs comme
EUR) peuvent être librement
utilisées. Les candidats ne devront faire appel à aucun autre module.
En Caml, les matrices d'entiers sont représentées par des tableaux de tableaux,
c'est-à-dire par le type int
array array. L'expression m.(i).(j) permet d'accéder au coefficient de la i-ème
ligne et de la j-ième colonne
de la matrice m. Dans le texte, en dehors du code Caml, ce coefficient sera
noté m{i, 5]. On rappelle les définitions
suivantes :
-- Array.make matrix : int -> int -> 'a -> 'a array array est telle que
Array.make matrix n p v
renvoie une matrice de n lignes et p colonnes dont toutes les cases contiennent
la valeur v ;
-- Array.length : 'a array -> int est telle que Array.length tab renvoie le
nombre d'éléments du ta-
bleau tab. Si tab est une matrice, c'est le nombre de lignes de tab ;
-- min : la -> 'a -> 'a renvoie le minimum des deux valeurs en argument ;
-- max : la -> 'a -> 'a renvoie le maximum des deux valeurs en argument ;
-- l'opérateur @ concatène deux listes. Par exemple, [2; 0] @ [4; 2] renvoie
[2; O0; 4; 2].
Dans ce problème, les graphes ont un ensemble de sommets de la forme
{0,1,...,n--1} et sont orientés complets
et pondérés par des entiers : pour tout couple (i,j) de sommets distincts, il
existe un arc de à à j de poids
M; EUR Z. Le graphe est représenté par sa matrice d'adjacence M = (mi; ;Joci
jen-1 avec la convention que
m;; = 0 pour tout sommet à (il n'y a pas d'arc d'un sommet vers lui-même).
I Vote par préférence
Nous considérons une élection, à laquelle se présentent n candidats. Chaque
électeur inscrit sur son bulletin
l'ensemble des candidats (tous les candidats sont classés), par ordre de
préférence. L'ensemble des bulletins est
rassemblé dans une urne. Le nombre de votants est noté p, l'urne contient donc
p bulletins.
Les trois types de données suivants sont utilisés pour représenter un vote :
-- type candidat = int ;; chaque candidat est désigné par un numéro de 0 à n--1;
-- type bulletin = candidat list ;; un bulletin de vote est une liste
(ordonnée) de candidats ;
-- type urne = bulletin list ;; une urne est un ensemble de bulletins de vote.
Par exemple, s'il y a trois candidats et qu'un électeur préfère le candidat 2,
puis le candidat 0 et enfin considère
que le candidat 1 est le moins souhaitable, son bulletin de vote sera [2; 0; 1].
Une fois le vote effectué, on compare les résultats de deux candidats
particuliers à et j en comptant le nombre
de bulletins qui classent le candidat à avant le candidat j. On exprime le
résultat de la comparaison entre les
candidats à et j en calculant la différence entre le nombre de bulletins de
vote qui placent à avant j et le nombre
de ceux qui placent j avant ti.
IA --- Premier exemple
On considère une élection avec trois candidat et trois votants : n = 3, p -- 3.
Les bulletins sont [2; 0; 1],
[2; 1; Olet [1; 2; 0]. La comparaison entre le candidat numéro 0 et le candidat
numéro 1 donne --1 car le
candidat 0 est placé une fois avant le candidat 1 et deux fois après.
Q 1. Écrire une fonction duel : candidat -> candidat -> urne -> int, telle que
duel i j u renvoie
la comparaison entre le candidat i et le candidat j à partir des bulletins
contenus dans l'urne u.
On peut alors synthétiser le contenu d'une urne u en construisant le graphe de
préférence des votants : ses
sommets correspondent aux candidats et l'arc du sommet i vers le sommet j est
pondéré par la comparaison
entre le candidat i et le candidat j, c'est-à-dire la valeur de duel i j u.
La figure 1 donne le graphe de préférence obtenu à partir du vote de l'exemple
1 ainsi que sa matrice d'adja-
cence M. Afin d'alléger le schéma, seuls les arcs avec un poids strictement
positif sont représentés.
2020-03-09 18:45:48 Page 1/4 CHE
O --1 -3
M=|1 0 1
ll 9 3 1 0
Figure 1
I.B --- Deuxième exemple
On considère une élection avec trois candidats et 4 votants : n = 3, p = 4. À
l'issue du vote, le contenu de l'urne
est [TO; 1; 2]; [1; 2; O0]; [0; 2; 1]; (0; 2; 111].
Q 2. Tracer le graphe de préférence de l'urne (en ne dessinant que les arcs
ayant un poids strictement
positif) et donner sa matrice d'adjacence.
IC --- Construction du graphe de préférence
Q 3. Expliquer pourquoi la matrice d'adjacence d'un graphe de préférence est
antisymétrique et pourquoi
tous ses coefficients non-diagonaux ont la même parité.
Étant donné une urne U, on note Mat(U) la matrice du graphe de préférence
associée à cette urne.
Q 4. Écrire une fonction depouillement : int -> urne -> int array array qui
prend en paramètres
le nombre de candidats n et une urne U et renvoie la matrice Mat(U).
ID --- Théorème de McGarvey
Le but de cette sous-partie est de démontrer le théorème de McGarvey : « Pour
toute matrice antisymétrique à
coefficients pairs M, il existe une urne U telle que M = Mat(U). »
Soient ?, j et n trois entiers naturels tels que à < n, j urne prenant en
paramètre une matrice anti-
symétrique M de coefficients tous pairs et renvoyant une urne U telle que M =
Mat(U).
Q 9. Estimer la complexité de la fonction megarvey en fonction de n, la taille
de la matrice (c'est-à-dire le
nombre de candidats), et de q, le maximum des coefficients de la matrice.
II Recherche du vainqueur
L'objectif de cette partie est de déterminer le vainqueur, ou les vainqueurs ex
aequo, d'un vote par préférence.
IT. À -- Vainqueur de Condorcet
On appelle vainqueur de Condorcet tout sommet tel que, dans le graphe de
préférence, les arcs sortant de ce
sommet ont tous un poids positif ou nul. Ainsi, dans le premier exemple de la
partie I, le candidat 2 est un
vainqueur de Condorcet.
Q 10. Expliquer pourquoi un vainqueur de Condorcet peut être qualifié de «
vainqueur » de l'élection.
Q 11. Écrire une fonction condorcet : int array array -> candidat list prenant
en paramètre la ma-
trice d'adjacence d'un graphe de préférence et renvoyant la liste des
vainqueurs de Condorcet.
Q 12. Ense plaçant dans le cas n = 8 et p = 3, construire une urne pour
laquelle il n'existe pas de vainqueur
de Condorcet. Tracer le graphe de préférence correspondant.
II.B - Graphe intermédiaire de Schultze
À la fin du xx° siècle, Markus Schulze imagina une méthode permettant de
déterminer un vainqueur à l'issue
de n'importe quel vote par préférence.
On appelle poids d'un chemin du graphe de préférence, le minimum des poids des
arcs constituant ce chemin.
Ainsi, dans le premier exemple de la partie I, le poids du chemin 2 -- 0 -- 1
est --1.
Le graphe intermédiaire de Schulze est un graphe orienté pondéré complet dont
les sommets sont les candidats
et dont l'arc du sommet à vers le sommet j (distinct de à) est pondéré par le
maximum des poids de tous les
chemins allant de à à 7 dans le graphe de préférence. Sa matrice d'adjacence
est notée J.
2020-03-09 18:45:48 Page 2/4 FO) 8y-Nc-sA
Q 13. Pouriet j, candidats distincts, démontrer que 1{[i, j] est aussi le
maximum des poids des chemins sans
boucle de ? à 7, c'est-à-dire des chemins ? = 49 -- 4, -- + -- 1, = 7 avec
15,1,,...,2, deux à deux distincts.
Q 14. Démontrer que min(Z{i, j|, 1[j,k]) < 1{[i, k] pour tout triplet (4, j,k) de sommets distincts. Q 15. En adaptant l'algorithme de Floyd-Warshall, programmer une fonction intermediaire : int array array -> int array array prenant en paramètre la matrice d'adjacence d'un
graphe de préférence et ren-
voyant la matrice d'adjacence du graphe intermédiaire de Schulze correspondant.
Q 16. Estimez la complexité de la fonction intermediaire en fonction de n, le
nombre de candidats.
Q 17. Scrait-il pertinent d'utiliser l'algorithme de Dijkstra au lieu de
l'algorithme de Floyd-Warshall ? Ar-
gumenter la réponse.
II.C --- Graphe de préférence de Schulze
Le graphe de préférence de Schulze est défini à partir du graphe intermédiaire
de Schulze. Si Z est la matrice
d'adjacence du graphe intermédiaire de Schulze, alors la matrice d'adjacence $
du graphe de préférence de
Schulze est définie par S{i, j] = 1{i, 5] -- 1[j,i] pour tous entiers naturels
à et j strictement inférieurs à n.
Q 18. Montrer que la matrice d'adjacence d'un graphe de préférence de Schulze
est antisymétrique et que
tous ses coefficients sont pairs.
Q 19. Écrire une fonction graphe _schulze : int array array -> int array array
qui prend en para-
mètre un graphe intermédiaire de Schulze et qui renvoie le graphe de préférence
de Schulze correspondant.
IT.D -- Vainqueur de Schulze
Un vainqueur de Schulze est un vainqueur de Condorcet dans le graphe de
préférence de Schulze.
Q 20. Écrire une fonction schulze : int -> urne -> candidat list qui prend en
paramètres le nombre
de candidats et un ensemble de bulletins de vote et renvoie la liste des
vainqueurs de Schulze.
Q 21. Estimer la complexité de la fonction schulze en fonction du nombre de
candidats n et du nombre de
votants p.
À partir d'un graphe de préférence de Schulze représenté par la matrice S, on
définit la relation R$ entre les
candidats comme suit : à R4 j si et seulement S{i, j] est strictement positif.
Q 22. Montrer que la relation À$ est transitive, c'est-à-dire que pour tous
candidats 2, 7 et k, sit Rs et
JR k alors ? Rç k.
Si I désigne la matrice d'adjacence du graphe intermédiaire, on pourra
distinguer les cas JZ{i, j] < 1{j,k] et Ifi, 5 > 1j, k|.
Q 23. Montrer que quelle que soit l'urne non vide considérée, il existe
toujours au moins un vainqueur de
Schulze.
III Satisfiabilité d'une formule de logique propositionnelle
Étant donné une variable propositionnelle +, on appelle littéral, les formules
x et -x (--x est la négation de x).
On appelle clause une disjonction de littéraux, par exemple x V --y V z est une
clause (V signifie « ou »).
On appelle conjonction de clauses, une formule qui est la conjonction entre
plusieurs clauses. Par exemple
(x V y V 2) A (x V --y) cest une conjonction de clauses (A signifie « et »).
On appelle interprétation une fonction qui à chaque variable propositionnelle
associe une valeur de vérité (vrai
ou faux).
On dit qu'une conjonction de clauses est satisfiable s'il existe une
interprétation qui la rend vraie, c'est-à-dire
qui rend vrai toutes ses clauses, autrement dit qui rend vrai au moins un
littéral de chacune de ses clauses.
Le problème SAT consiste à déterminer si une conjonction de clauses est
satisfable :
Entrées : Une conjonction de clauses @.
Sortie : Un booléen. Vrai si & est satisfñable. Faux sinon.
Q 24. Montrer qu'il est possible de résoudre le problème SAT avec une
complexité en O(2"m) où n est le
nombres de variables distinctes et m le nombre de littéraux de l'entrée
(comptés avec leurs répétitions).
On considère un vote par préférence pour lequel on a réparti les candidats en
trois groupes :
-- un candidat c, appelé champion :
-- un ensemble À de candidats dits automatiques ;
-- un ensemble B de candidats optionnels.
2020-03-09 18:45:48 Page 3/4 FO) 8y-Nc-sA
Le problème appelé CONTROL-ADD-ALT consiste à déterminer s'il est possible
d'éliminer un certain nombre
de candidats optionnels de façon à ce que c soit un vainqueur de Schulze de
l'élection :
Entrées : Le candidat c. L'ensemble À. L'ensemble B. Le graphe de préférence G
du vote sur l'ensemble des
candidats {c} U À U B. Un budget k EUR N.
Sortie : Un booléen. Vrai, s'il est possible de choisir k candidats distincts
b,,...,b,; dans B tels que c est un
vainqueur de Schulze de l'élection en considérant uniquement l'ensemble de
candidats {c} U À U {b,,...,b,}.
Faux sinon.
Pour obtenir le graphe de préférence de l'élection avec l'ensemble de candidats
{c} U A U {b,,..,b;}, on prend
le graphe de préférence sur l'ensemble des candidats {c} U À U B et on supprime
les candidats de B qui n'ont
pas été choisis (ainsi que les arrêtes entrantes et sortantes de ces candidats).
On appelle instance de CONTROL-ADD-ALT une entrée du problème CONTROL-ADD-ALT
et instance de
SAT une entrée du problème SAT.
On considère l'algorithme « Transformation d'une formule en élection » qui,
étant donné une instance de SAT
(c'est-à-dire une conjonction de clauses), construit une instance de
CONTROL-ADD-ALT :
Entrées : Une conjonction de clauses
Sortie : Un candidat c (le champion), un ensemble de candidats automatiques À,
un ensemble de candidats
optionnels B, un budget k, un graphe de préférence G sur l'ensemble de
candidats {c} U AU B
V+
pour tout x variable propositionnelle apparaissant dans 4 faire
de dA(xV -x)
fin pour
Créer un nouveau candidat EUR
Créer un graphe G avec un seul sommet EUR
Ati, B«(
pour tout ci clause de Y faire
Créer un nouveau candidat a,, associé à cl et l'ajouter à G et à À
Ajouter à G un arc de poids +4 de à, vers c et un arc de poids --4 en sens
inverse.
fin pour
pour tout x variable propositionnelle apparaissant dans Y faire
Créer un nouveau candidat b,, associé au littéral x et l'ajouter à G et à B
Créer un nouveau candidat b_.. associé au littéral --x et l'ajouter à G et à B
Ajouter à G deux arcs de poids +6 de c vers b, et vers b_. puis ajouter deux
arcs de poids --6 en sens
inverse.
fin pour
pour tout couple (li, cl) avec li un littéral de + et cl une clause de Y
contenant le littéral li faire
Ajouter à G un arc de poids +6 de b,; vers à, et un arc de poids --6 en sens
inverse.
fin pour
Compléter le graphe G& avec des arrêtes de poids nul pour le rendre complet.
k «le nombre de variables propositionelles qui apparaissent dans w.
renvoyer c, À, B, G, k.
Q 25. Donner le graphe de préférence créé à partir de la formule (x V x) A (x V
-x). Est-il possible de choisir
k = 1 candidat parmi x et --x de sorte que c gagne ?
Q 26. Montrer que si on peut choisir k candidats optionnels de sorte à faire
gagner le champion, alors, pour
toute variable propositionnelle x, on a choisi x ou --x mais on n'a pas choisit
x et --x.
Q 27. Justifier que & est satisfiable si et seulement si l'instance de
CONTROL-ADD-ALT créée par cet
algorithme à partir de & donne une réponse positive.
On dit qu'un algorithme est en temps polynomial en un paramètre m, si la
complexité de cet algorithme est
majorée par un polynôme en m.
Conjecture. Il n'existe pas d'algorithme en temps polynomial en nombre de
littéraux de l'entrée qui résout
SAT.
Q 28. Montrer que, si la conjecture précédente est vraie, alors il n'existe pas
d'algorithme en temps polyno-
mial en nombre de candidats qui résout CONTROL-ADD-ALT.
ee erFINee.e
2020-03-09 18:45:48 Page 4/4 FO) 8y-Nc-sA