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

Version interactive avec LaTeX compilé

Mines Option Informatique MP 2017

Notez ce sujet en cliquant sur l'étoile
0.0(0 votes)
Logo mines
2025_08_29_ae2d70d38652fabaf546g

ÉCOLE DES PONTS PARISTECH, ISAE-SUPAERO, ENSTA PARISTECH, TELECOM PARISTECH, MINES PARISTECH, MINES SAINT-ÉTIENNE, MINES NANCY, IMT Atlantique (ex Télécom Bretagne), ENSAE PARISTECH.

Concours Centrale-Supelec (Cycle International), Concours Mines-Télécom, Concours Commun TPE/EIVP.

CONCOURS 2017

ÉPREUVE D'INFORMATIQUE MP

Durée de l'épreuve : heures

L'usage de la calculatrice et de tout dispositif électronique est interdit.
Cette épreuve concerne uniquement les candidats de la filière MP.
Les candidats sont priés de mentionner de façon apparente sur la première page de la copie :
INFORMATIQUE - MP
L'énoncé de cette épreuve comporte 7 pages de texte.

Abstract

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.

Première partie : langages et automates

On s'intéresse aux langages sur l'alphabet ; un tel langage est dit unaire. Un automate reconnaissant un langage unaire sera dit unaire. Lorsqu'on dessinera un automate unaire, il ne sera pas utile de faire figurer les étiquettes des transitions, toutes ces étiquettes étant l'étiquette . C'est ce qui est fait dans cet énoncé.
Dans un automate unaire, on appelle chemin une suite d'états telle que, pour compris entre 1 et , il existe une transition de vers ; on dit qu'il s'agit d'un chemin de à . On appelle circuit un chemin tel qu'il existe une transition de vers .
Dans cet exercice, tous les automates considérés seront finis et auront un et un seul état initial. On dit qu'un automate est émondé si, pour tout état , il existe d'une part un chemin de l'état initial à et d'autre part un chemin de à un état final.
On rappelle qu'un langage non vide est rationnel si et seulement s'il est reconnu par un automate ou encore si et seulement s'il est reconnu par un automate déterministe émondé.
Soient et deux entiers positifs ou nuls. On note le langage unaire défini par :
entier positif ou nul .
- Donner sans justification une condition nécessaire et suffisante pour que soit fini. Dans le cas où cette condition est satisfaite, donner sans justification le cardinal de .
2 - On considère l'automate ci-dessous. Indiquer sans justification deux entiers tels que reconnaisse le langage .
3 - On considère l'automate ci-dessous :
On note le langage reconnu par . Indiquer sans justification quatre entiers , tels que reconnaisse le langage .
  • 4 - Construire un automate déterministe émondé en appliquant la procédure de déterminisation à l'automate .
    - En s'appuyant sur l'automate , indiquer sans justification cinq entiers , , tels que reconnaisse le langage (remarque : le langage est égal par ailleurs au langage ).
On dit ci-dessous qu'un automate est de la forme si, en omettant les états finals, il peut se tracer selon le schéma ci-dessous :
Le chemin peut être vide, auquel cas on a . Le circuit ne doit pas être vide mais on peut avoir avec une transition de l'état vers lui-même (un tel circuit s'appelle aussi une boucle). On constate que les automates et sont de la forme , mais non .
- Dessiner sans justification un automate de la forme qui reconnaît le langage . On fera figurer le ou les état(s) final(s).
ATTENTION : on ne demande aucune justification mais uniquement de tracer un automate de la forme en choisissant correctement les longueurs du chemin et du circuit et en ajoutant le ou les état(s) final(s).
- Dessiner un automate de la forme qui reconnaît le langage . On fera figurer le ou les état(s) final(s). Comme à la question précédente, on ne demande aucune justification.
  • 8 - En s'inspirant de la réponse à la question précédente, décrire sans justification un automate de la forme qui reconnaît le langage . Indiquer deux entiers et tels qu'on ait la relation : .
  • 9 - Montrer qu'un automate déterministe émondé qui reconnaît un langage unaire rationnel infini est de la forme . Donner une condition nécessaire et suffisante portant sur les états finals pour qu'un automate de la forme reconnaisse un langage infini.
    Soit un langage rationnel unaire infini. En s'appuyant sur la question précédente, montrer qu'il existe deux entiers et tels que contient .
    - On considère une suite de nombres entiers positifs ou nuls. On suppose que la suite est positive et strictement croissante. Soit le langage défini par : . En utilisant la question précédente, montrer que n'est pas rationnel.
    - Montrer que le langage défini par n'est pas rationnel.

Seconde partie : algorithmique et programmation

Préliminaire concernant la programmation

Il faudra coder des fonctions à l'aide du langage de programmation Caml, tout autre langage étant exclu. Lorsque le candidat écrira une fonction, il pourra faire appel à d'autres fonctions définies dans les questions précédentes ; il pourra aussi définir des fonctions auxiliaires. Quand l'énoncé demande de coder une fonction, il n'est pas nécessaire de justifier que celle-ci est correcte, sauf si l'énoncé le demande explicitement. Enfin, si les paramètres d'une fonction à coder sont supposés vérifier certaines hypothèses, il ne sera pas utile dans l'écriture de cette fonction de tester si les hypothèses sont bien vérifiées.
Dans les énoncés de l'exercice, 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 ) 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 représentable.
On pourra utiliser les fonctions suivantes.
  • La fonction empiler ajoute une valeur en début d'une liste dont la référence est passée en paramètre ; par exemple si on a :
    let liste = ref [1; 2; 3];;
    après l'instruction: empiler liste 5 ;;
    !liste vaut [5; 1; 2; 3].
  • La fonction depiler retire la valeur du début d'une liste dont la référence est passée en paramètre et renvoie la valeur retirée ; par exemple si on a :
    let liste = ref [1; 2; 3];;
    après l'instruction: let val = depiler liste;;
    ! liste vaut [ 2 ; 3] et val vaut 1 .
    Cette fonction ne doit être utilisée que si la liste dont la référence est passée en paramètre n'est pas vide.
  • La fonction longueur renvoie la longueur d'une liste passée en paramètre.
  • La fonction inverse reçoit en paramètre une liste et renvoie une nouvelle liste qui est l'inverse de la première. Par exemple, si on a :
    let liste = [1; 2; 3];;
    l'instruction inverse liste; ; renvoie la liste [3; 2; 1].
    On considère un ensemble muni d'une loi de composition interne associative appelée multiplication et possédant un élément neutre pour cette loi noté . Cette multiplication est notée avec le signe .
    Par exemple, peut être l'ensemble des entiers ou des réels munis de la multiplication usuelle, l'élément neutre étant 1 . L'ensemble peut aussi être l'ensemble des matrices carrées booléennes (respectivement d'entiers, de réels) d'une même dimension avec le produit usuel comme multiplication, l'élément neutre étant la matrice identité booléenne (respectivement entière, réelle) de dimension .
    Soit un élément de et soit un entier positif ou nul. On définit de la façon suivante :
  • ,
  • .
La multiplication étant associative, si et sont deux entiers positifs ou nuls de somme égale à , on a : .
Un élément de et un entier supérieur ou égal à 1 étant donnés, on cherche à calculer en s'intéressant au nombre de multiplications effectuées.
Dans toute la suite, et désignent respectivement un élément quelconque de et un entier strictement positif.
Exemple . On peut calculer en multipliant 13 fois l'élément par lui-même. On effectue ainsi 13 multiplications.
Exemple 2 : . On peut calculer en calculant par , puis par puis par , puis par , puis enfin . On a ainsi obtenu le résultat en effectuant 5 multiplications.
Exemple . On peut aussi calculer en calculant par , puis par , puis par puis par , puis par . On a ainsi obtenu le résultat en effectuant encore 5 multiplications.
L'objectif est de déterminer des algorithmes qui effectuent peu de multiplications. Soit un nombre réel positif ; on note la partie entière par défaut de et sa partie entière par excès.
On appelle suite pour l'obtention de la puissance toute suite non vide croissante d'entiers distincts telle que :
  • ,
  • ,
  • pour tout indice vérifiant , il existe deux entiers et distincts ou non vérifiant et (la paire n'est pas nécessairement unique).
À une suite pour l'obtention de la puissance correspond une suite de multiplications conduisant au calcul de . Par exemple, la suite ( ) correspond au calcul de en faisant les 6 multiplications suivantes : , .
Réciproquement, considérons un calcul de dans lequel on fait en sorte d'ordonner les multiplications pour que les puissances calculées soient d'exposants croissants; on peut associer à ce calcul une suite pour l'obtention de la puissance .
À l'exemple 1 est associée la suite , de longueur 14 .
À l'exemple 2 est associée la suite ( ), de longueur 6 .
À l'exemple 3 est associée la suite , de longueur 6 .
Le nombre de multiplications correspondant à une suite pour l'obtention de la puissance est égal à la longueur de la suite diminuée de 1 .
13 - Montrer que tout calcul de qui n'utilise que des multiplications nécessite un nombre de multiplications au moins égal à . Donner une famille infinie de valeurs de qui peuvent être calculées en effectuant exactement ce nombre de multiplications ; justifier la réponse.
On considère un algorithme appelé par_division ayant pour objectif le calcul de . Cet algorithme s'appuie sur le principe récursif suivant :
si vaut 1, alors vaut , sinon
  • on calcule la partie entière par défaut, notée , de ,
  • on calcule par l'algorithme par_division la valeur de ,
  • si est pair, alors , sinon .
Ainsi, pour obtenir , l'algorithme par_division fait appel au calcul de qui fait appel au calcul de (pour obtenir en multipliant par puis en multipliant par ) qui fait appel au calcul de (pour obtenir puis ). Les différentes puissances calculées sont les puissances et 14 . On constate ainsi que la suite pour l'obtention de la puissance 14 correspondant à l'algorithme par_division est la suite ( ), de longueur 6 . De même, la suite pour l'obtention de la puissance 19 correspondant à l'algorithme par_division est la suite de longueur 7.
- Calculer (sans justification) la suite correspondant à l'algorithme par_division successivement:
  • pour l'obtention de la puissance 15 ;
  • pour l'obtention de la puissance 16 ;
  • pour l'obtention de la puissance 27 ;
  • pour l'obtention de la puissance 125.
Dans chaque cas, indiquer la longueur de la suite obtenue.
  • 15 - Écrire en Caml la fonction nommée par_division qui calcule la suite pour l'obtention de la puissance correspondant à l'algorithme par_division. Si n est une valeur entière strictement positive, par_division n renvoie une liste contenant la suite pour l'obtention de la puissance .
  • 16 - Montrer que l'algorithme par_division pour l'obtention de la puissance effectue au plus multiplications. Montrer que ce nombre est atteint pour un nombre infini de valeurs de .
On considère maintenant un algorithme appelé par_decomposition_binaire dont l'objectif est aussi le calcul de . Cet algorithme utilise la décomposition d'un entier suivant les puissances de 2. L'algorithme est expliqué ci-dessous à l'aide d'exemples.
  • Soit . On décompose 14 selon les puissances de . On a donc : , ce qui conduit à calculer les puissances de d'exposants mais aussi 6 et 14 ; la suite pour l'obtention de la puissance 14 correspondant à cet algorithme est la suite .
  • Soit . On a : , ce qui implique : . L'algorithme calcule les puissances d'exposants puis 18 ; la suite pour l'obtention de la puissance 18 correspondant à cet algorithme est : ( ).
  • Soit . On a : . L'algorithme calcule en utilisant les multiplications impliquées par la formule : ; on calcule les puissances 2, 4, 5 (pour ), 8, 16, 32, 37 (pour ), 64 et 101 (pour ); la suite pour l'obtention de la puissance 101 correspondant à cet algorithme est : .
De manière générale, l'algorithme procède en écrivant la décomposition unique de comme une somme de puissances croissantes du nombre 2, et calcule la valeur cible de en effectuant les produits correspondant aux sommes partielles de cette somme.
17-Calculer (sans justification) la suite correspondant à l'algorithme par_decomposition_binaire successivement :
  • pour l'obtention de la puissance 15 ;
  • pour l'obtention de la puissance 16 ;
  • pour l'obtention de la puissance 27 ;
  • pour l'obtention de la puissance 125.
Dans chaque cas, indiquer la longueur de la suite obtenue.
On considère la décomposition de suivant les puissances croissantes du nombre 2 :
où, pour vérifiant , le coefficient vaut 0 ou 1 et vaut 1 .
On appelle écriture binaire inverse de la suite ( ).
Par exemple, l'écriture binaire inverse de l'entier 14 est ( ), celle de l'entier 18 est ( ) et celle de l'entier 101 est ( ).
18 - Écrire en Caml une fonction nommée binaire_inverse qui calcule l'écriture binaire inverse d'un nombre donné. Si n est une valeur entière strictement positive, alors binaire_inverse n renvoie une liste contenant l'écriture binaire inverse de .
19 - Écrire en Caml la fonction par_decomposition_binaire qui calcule la suite pour l'obtention de la puissance correspondant à l'algorithme par_decomposition_binaire. Si n est une valeur entière strictement positive, par_decomposition_binaire n renvoie une liste contenant la suite cherchée.
  • 20 - On suppose que l'on a , où est un entier positif ou nul. En utilisant la formule : , montrer qu'il existe une suite pour l'obtention de la puissance de longueur . Indiquer une telle suite correspondant à ; comparer la longueur de cette suite à la longueur de la suite correspondant à l'algorithme par_division.
    - Soit un entier positif ou nul. Écrire en Caml une fonction suite_3 calculant une suite de longueur pour l'obtention de la puissance . On s'appuiera pour cela sur la question précédente. Si est une valeur entière positive ou nulle, suite_3 renvoie une liste contenant la suite cherchée.
    On suppose que l'on a , où est un entier positif ou nul quelconque. Montrer qu'il existe une suite pour l'obtention de la puissance de longueur . Indiquer la suite correspondant à ; comparer la longueur de cette suite à la longueur de la suite correspondant à l'algorithme par_division.
    - Donner une suite de longueur 6 pour l'obtention de la puissance 15. Qu'en déduire quant aux algorithmes par_division et par_decomposition_binaire étudiés précédemment?
24 - On considère un tableau (ou vecteur) , indicé à partir de 0 , contenant une suite pour l'obtention d'une certaine puissance positive . Soit un entier compris entre 1 et la longueur de diminuée de 1 . Soit val la valeur contenue dans à l'indice . On sait que val est la somme de deux valeurs du tableau situées à des indices (éventuellement confondus, éventuellement non uniques) strictement inférieurs à . Il s'agit de programmer une fonction nommée chercher_indice qui détermine ces deux indices. Par exemple, si tableau contient les valeurs , la longueur du tableau vaut 8, et, si vaut 6, alors val vaut 17 et la fonction chercher_indice doit renvoyer les indices 2 et 5 correspondant aux valeurs 3 et 14 du tableau ; si, avec ce même tableau, vaut 1 , la fonction doit renvoyer 0 et 0 . Écrire en Caml la fonction chercher_indice telle que, si :
  • T code un vecteur contenant une suite pour l'obtention d'une certaine puissance positive (la valeur de est inutile pour l'écriture de la fonction),
  • code un entier compris entre 1 et la longueur de diminuée de 1 , alors chercher_indice T k renvoie une liste de deux entiers contenant les deux indices cherchés, par ordre croissant. Indiquer (sans justification) la complexité de cette fonction.
25 - Dans cette question, est l'ensemble des réels. Soit un nombre réel quelconque et soit un tableau (ou vecteur) contenant une suite pour l'obtention d'une certaine puissance positive . Écrire en Caml une fonction puissance qui calcule la valeur de en utilisant le tableau . Si x est une valeur de type float et code un vecteur contenant une suite pour l'obtention d'une certaine puissance positive , alors puissance x T renvoie la valeur de en effectuant des multiplications suivant la suite représentée par .

Indications :

  • on utilisera la fonction chercher_indice de la question précédente ; en appelant la longueur de , la complexité de la fonction puissance devra nécessairement être en (il n'est pas demandé de justifier cette complexité) ;
  • si T est un vecteur, vect_length T donne la longueur de T ;
  • l'opérateur *. permet de faire le produit de deux valeurs de type float.
  • 26- Décrire le principe d'une fonction nommée suite_optimale permettant d'exhiber une suite de longueur minimale pour l'obtention de la puissance , en effectuant une énumération exhaustive des suites possibles. Cette fonction devra utiliser une fonction récursive nommée suite_optimale_rec dont on donnera aussi le principe.
  • 27 - Écrire en Caml les fonctions suite_optimale_rec et suite_optimale correspondant aux fonctions de la question précédente. Si n est une valeur de type int, alors suite_optimale_rec renvoie une liste contenant une suite de longueur minimale pour l'obtention de la puissance .
Mines Option Informatique MP 2017 - Version Web LaTeX | WikiPrépa | WikiPrépa