J-0
00m
00j
00h
00min
00s

Version interactive avec LaTeX compilé

Mines Option Informatique MP 2014

Notez ce sujet en cliquant sur l'étoile
0.0(0 votes)
Logo mines
2025_08_29_161303008d1ba08db97dg
A 2014 INFO. MP
ECOLE DES PONTS PARISTECH, SUPAERO (ISAE), ENSTA PARISTECH, TELECOM PARISTECH, MINES PARISTECH, MINES DE SAINT-ETIENNE, MINES DE NANCY, TELECOM BRETAGNE, ENSAE PARISTECH (FILIERE MP) ECOLE POLYTECHNIQUE (FILIERE TSI)
CONCOURS 2014
EPREUVE d'INFORMATIQUE
Filière : MP
Durée de l'épreuve : 3 heures.
L'utilisation d'une calculatrice est autorisée.
Sujet mis à la disposition des concours :
Cycle International, ecoles des Mines, TELECOM SudParis, TPE-EIVP.
L'énoncé de cette épreuve comporte 8 pages.
Les candidats sont priés de mentionner de façon apparente
sur la première page de la copie :
INFORMATIQUE - MP
Recommandations aux candidats
  • Si, au cours de l'épreuve, un candidat repère ce qui lui semble être une erreur d'énoncé, il le signale sur sa copie et poursuit sa composition en expliquant les raisons des initiatives qu'il est amené à prendre.
  • Tout résultat fourni dans l'énoncé peut être utilisé pour les questions ultérieures même s'il n'a pas été démontré.
  • Il ne faut pas hésiter à formuler les commentaires qui semblent pertinents même lorsque l'énoncé ne le demande pas explicitement.

Composition de l'épreuve

L'épreuve est constituée :
  • d'un exercice sur les automates et les langages : pages 2 et 3 ;
  • d'un problème d'algorithmique et programmation : pages 3 à 8 .

Première partie : automates et langages

Un alphabet est un ensemble fini d'éléments appelés lettres. Un mot sur est une suite finie, éventuellement vide, de lettres de ; la longueur d'un mot est le nombre de lettres composant et est notée ; le mot de longueur nulle est noté . On note par l'ensemble de tous les mots sur . Un langage sur est une partie de .
Soit un mot sur un alphabet ; pour toute lettre de , on note le nombre d'occurrences de la lettre dans le mot .
On note l'ensemble des entiers naturels.
On considère dans cet exercice l'alphabet .
Soit une application quelconque définie sur et à valeurs dans . On note l'ensemble des mots appartenant à vérifiant l'égalité .
- On considère la fonction définie par: . Dessiner un automate reconnaissant le langage .
On considère la fonction définie par: si est pair et sinon.
2 - Décrire par une expression rationnelle de la forme , où et sont des expressions rationnelles à déterminer. Justifier la réponse.
Remarque : on note aussi | l'opérateur noté + dans l'expression rationnelle ci-dessus.
3 - Dessiner un automate non nécessairement déterministe reconnaissant le langage décrit par l'expression rationnelle . Cet automate devra nécessairement posséder un seul état initial et un seul état final.
4 - En s'appuyant sur l'expression rationnelle obtenue à la question , compléter l'automate obtenu à la question précédente pour obtenir un automate non déterministe reconnaissant le langage . Cet automate devra nécessairement posséder un seul état initial et un seul état final.
5 - Déterminiser l'automate obtenu à la question précédente. On utilisera un algorithme vu en cours et on ne fera apparaître que les états accessibles depuis l'état initial.
6 - Montrer que si n'est pas majorée par une constante, alors n'est pas rationnel.
7 - On considère le langage sur défini par vérifiant . Le langage est-il rationnel ?
8 - On considère le langage sur défini par: avec . Le langage ééé
- On considère le langage sur défini par: avec . Le langage est-il rationnel ? On utilisera le résultat de la question précédente.
- Montrer que la réciproque de la proposition énoncée dans la question est fausse.
Indication : on pourra admettre que le langage des mots de la forme est une lettre et est un entier premier n'est pas rationnel.

Seconde partie : logique et programmation

Préliminaire concernant la programmation

Il faudra écrire des fonctions ou des procédures à l'aide d'un langage de programmation qui pourra être soit Caml, soit Pascal, tout autre langage étant exclu. Indiquer en début d'épreuve le langage de programmation choisi; il est interdit de modifier ce choix au cours de l'épreuve. Certaines questions du problème sont formulées différemment selon le langage de programmation ; cela est indiqué chaque fois que cela est nécessaire. Lorsque le candidat écrira une fonction ou une procédure, il pourra faire appel à une autre fonction ou procédure définie dans les questions précédentes; il pourra aussi définir une procédure ou une fonction auxiliaire. Enfin, si les paramètres d'une fonction ou d'une procédure à écrire sont supposés vérifier certaines hypothèses, il ne sera pas utile, dans l'écriture de cette fonction ou de cette procédure, de tester si les hypothèses sont bien vérifiées.
Dans les énoncés du problème, un même identificateur écrit dans deux polices de caractères différentes désignera la même entité, mais du point de vue mathématique pour la police en italique (par exemple n) et du point de vue informatique pour celle en romain (par exemple n).
On ne se préoccupera pas d'un éventuel dépassement du plus grand entier codable dans le langage de programmation choisi.

Indications pour la programmation
Caml

Si n est un entier, l'instruction
let A = make_matrix n n false;;
permet de construire une matrice carrée booléenne à lignes et colonnes, et dont les cases sont initialisées à false.
Fin des indications pour Caml

Pascal

On utilisera dans tout le sujet les déclarations ci-dessous.
CONST MAX = 100;
type Tableau_Boolean = array [0 .. MAX - 1] of Boolean;
type Matrice_Boolean = array [0 .. MAX - 1] of Tableau_Boolean;
On supposera que la constante MAX est suffisamment grande pour que les tableaux et matrices de types Tableau_Boolean et Matrice_Boolean puissent coder les tableaux et matrices considérés dans ce problème.

Fin des indications pour Pascal

On considère un ensemble fini de propositions logiques distinctes : , . On suppose qu'un ensemble d'implications entre ces propositions, appelé ensemble des implications initiales et noté , a déjà été établi. On peut en général déduire d'autres implications à partir de l'ensemble des implications initiales en utilisant la transitivité des implications : pour deux propositions et appartenant à , si se déduit de à l'aide d'une suite d'implications appartenant à , on dit que « implique », ce que l'on note . Dans toute la suite, on s'intéresse aux implications que l'on peut déduire de .
Pour tout dans , on suppose que contient l'implication ; une telle implication, nommée boucle, est notée .
Si et sont dans , la notation signifie que l'implication appartient à (pour tout dans , on a donc aussi ).
Exemple 1 : , .
Exemple 2 : , .
Pour et dans implique (autrement dit, ) s'il existe un entier et propositions appartenant à 7 tels que l'on ait :
  • ,
  • ,
  • pour vérifiant , l'implication appartient à .
Avec les notations ci-dessus, on dit alors qu'il existe une preuve de longueur de l'implication , ce que l'on note . Les implications de sont donc les preuves de longueur 0 (si ) ou 1 .
Dans l'exemple 1, on a car on a et ; on a aussi car on peut ajouter une boucle en considérant les trois implications et . En revanche, on n'a pas : .
Dans l'exemple 1, les implications qui peuvent être prouvées mais qui n'appartiennent pas à sont : .
11 - Pour l'exemple 2, donner la liste des implications qui peuvent être prouvées mais qui n'appartiennent pas à .
- Soient et dans ; soient et deux entiers positifs ou nuls vérifiant : . Montrer que si on a , alors on a aussi .
- Soient et dans . Montrer qu'on a l'implication si et seulement si on a .
Une matrice booléenne est une matrice dont les coefficients prennent uniquement les valeurs faux et vrai (false et true en langage de programmation). Le produit de matrices booléennes s'obtient selon la formule habituelle en prenant comme somme de deux valeurs booléennes le «ou logique» (disjonction, notée V) et comme produit de deux valeurs booléennes le «et logique» (la conjonction, notée ); le produit de deux matrices et est noté .
Par exemple, si on considère les deux matrices : et , le produit vaut .
On ne s'intéressera dans ce problème qu'à des matrices carrées ; la dimension d'une matrice carrée est son nombre de lignes (et donc de colonnes). Si est un entier strictement positif, on obtient la matrice en multipliant fois la matrice par elle-même.
14 - On considère deux matrices carrées booléennes et de même dimension . Il s'agit d'écrire en langage de programmation le calcul du produit .
Caml : Écrire en Caml une fonction nommée mult telle que, si A et B codent et , alors mult A B renvoie une matrice codant le produit A .
Pascal : Écrire en Pascal une fonction nommée mult telle que si :
  • A et B , de type Matrice_Boolean, codent et ,
  • d, de type Integer, contient la valeur de , alors mult (A, B, d) renvoie une matrice, de type Matrice_Boolean, codant le produit .
On considère encore l'ensemble des propositions logiques et l'ensemble d'implications initiales entre ces propositions. On associe à et une matrice carrée booléenne de dimension définie de la façon suivante :
  • les lignes et les colonnes de sont indicées de 0 à ;
  • soient et deux entiers vérifiant et ; en notant le coefficient de situé sur la ligne d'indice et la colonne d'indice vaut vrai si et seulement si l'implication appartient à .
Ainsi, les matrices et correspondant respectivement à l'exemple 1 et à l'exemple 2 sont:

- Montrer que, pour et vérifiant et pour tout strictement positif, le coefficient vaut vrai si et seulement si on a .
16 - Montrer que, pour tout , on a .
On appelle fermeture transitive de et on note la matrice .
- Il s'agit d'écrire en langage de programmation une fonction nommée qui calcule la fermeture transitive de en utilisant des multiplications de matrice.
Caml : Écrire en Caml la fonction FT telle que, si A code la matrice , alors FT A renvoie la matrice .
Pascal : Écrire en Pascal la fonction FT telle que si :
  • A, de type Matrice_Boolean, code la matrice ,
  • n , de type Integer, contient la dimension de , alors , de type Matrice_Boolean, renvoie la matrice .
18 - Soit une proposition appartenant à . Il s'agit d'écrire en langage de programmation une fonction nommée deduction qui détermine toutes les propositions appartenant à 7 telles que l'on ait . On utilisera pour cela la récursivité.
ATTENTION : On exige que la complexité de cette fonction soit de l'ordre de . On ne justifiera pas la complexité de la fonction qui sera écrite.
Caml : Écrire en Caml la fonction deduction telle que si :
  • A code la matrice ,
  • i est un entier compris entre 0 et ,
    alors deduction A i renvoie un tableau de booléens de longueur tel que, pour compris entre 0 et , la valeur d'indice j de ce tableau vaut true si et seulement si on a .
    Pascal : Écrire en Pascal la fonction deduction telle que si :
  • A, de type Matrice_Boolean, code la matrice ,
  • n , de type Integer, contient la valeur de ,
  • , de type Integer, contient un entier compris entre 0 et , alors deduction(A, n, i) renvoie un tableau de type Tableau_Boolean tel que, pour compris entre 0 et , la valeur d'indice de ce tableau vaut true si et seulement si on a .
19 - Il s'agit d'écrire en langage de programmation une fonction nommée FT_bis de complexité calculant la matrice .
Caml : En utilisant la fonction deduction, écrire en Caml la fonction FT_bis telle que si A code la matrice , alors FT_bis A renvoie la matrice .
Pascal : En utilisant la fonction deduction, écrire en Pascal la fonction FT_bis telle que si :
  • A, de type Matrice_Boolean, code la matrice ,
  • n , de type Integer, contient la valeur de , alors FT_bis(A, n) renvoie la matrice .
Soient et deux propositions appartenant à . On dit que les propositions et sont équivalentes si on a : et .
Soit appartenant à . On dit ici que est un axiome si on a la propriété suivante : quelle que soit la proposition appartenant à , si on a , alors on a aussi et donc et sont équivalentes; autrement dit, est équivalente à toute proposition qui l'implique.
20 - Donner tous les axiomes dans l'exemple 1.
21 - Donner tous les axiomes dans l'exemple 2.
On pose . Des questions précédentes, on déduit que, si et sont deux entiers compris entre 0 et , on a si et seulement si vaut vrai.
22 - Il s'agit, connaissant la matrice , de programmer une fonction est_axiome qui indique si une proposition donnée est ou non un axiome.
Caml : Écrire en Caml la fonction est_axiome telle que si :
  • B code la matrice B,
  • i est un entier compris entre 0 et , alors est_axiome B i renvoie la valeur true si est un axiome et la valeur false sinon.
    Pascal : Écrire en Pascal la fonction est_axiome telle que si :
  • B, de type Matrice_Boolean, code la matrice B,
  • n , de type Integer, contient la valeur de ,
  • i , de type Integer, contient un entier compris entre 0 et , alors est_axiome(B, n, i) renvoie la valeur true si est un axiome et la valeur false sinon.
On appelle suite unidirectionnelle de propositions une suite ( ), où est un entier positif ou nul, telle que :
  1. pour vérifiant appartient à ,
  2. pour vérifiant ,
  3. pour vérifiant n'implique pas .
    23 - Montrer que les propositions d'une suite unidirectionnelle de propositions sont deux à deux distinctes.
    24 - Soit une proposition appartenant à . Montrer qu'il existe un axiome avec .
On admet le résultat suivant : on peut partitionner en sous-ensembles de sorte que deux propositions de soient équivalentes si et seulement si elles appartiennent au même sousensemble. On appelle classes d'équivalence ces sous-ensembles.
Par définition : les classes d'équivalence sont non vides, l'union des classes d'équivalence est égale à , l'intersection de deux classes d'équivalence est vide.
Dans l'exemple 1, il y a deux classes d'équivalence : les classes et .
25 - Donner les classes d'équivalence dans l'exemple 2.
26 - On considère une classe d'équivalence contenant un axiome. Montrer que toutes les propositions contenues dans sont des axiomes.
On dit qu'une classe d'équivalence est une classe source si elle contient un axiome (auquel cas tous les éléments de la classe source sont des axiomes).
Soit une partie de . On dit ici que est une axiomatique si, quelle que soit la proposition appartenant à , il existe une proposition appartenant à vérifiant .
- Montrer qu'on obtient une axiomatique de cardinal minimum en choisissant une et une seule proposition dans chacune des classes sources.
- On pose encore . Il s'agit d'écrire en langage de programmation une fonction nommée axiomatique qui détermine une axiomatique de cardinal minimum. On pourra utiliser un tableau pour éliminer, lorsqu'on a choisi un axiome, les axiomes qui lui sont équivalents.
Caml : Écrire en Caml la fonction axiomatique telle que, si B code la matrice B, alors axiomatique renvoie une liste d'entiers contenant les indices de propositions de formant une axiomatique de cardinal minimum.
Pascal :
On définit le type suivant :
type Pile = record
table : array [0 .. MAX - 1] of Integer;
nb : Integer;
end;
Si P est de type Pile, P code une pile de P.nb entiers situés dans P. table entre les indices 0 et .
Écrire en Pascal la fonction axiomatique telle que si :
  • B, de type Matrice_Boolean, code la matrice B,
  • n , de type Integer, contient la valeur de ,
    alors axiomatique( ) renvoie un résultat de type Pile contenant les indices de propositions de 7 formant une axiomatique de cardinal minimum.
Mines Option Informatique MP 2014 - Version Web LaTeX | WikiPrépa | WikiPrépa