28.09.2015 Views

PDF (105 Ko) - Sujets de Concours

PDF (105 Ko) - Sujets de Concours

PDF (105 Ko) - Sujets de Concours

SHOW MORE
SHOW LESS

Create successful ePaper yourself

Turn your PDF publications into a flip-book with our unique Google optimized e-Paper software.

Épreuve d’informatique 2013<br />

❒ 12 – On suppose que p est un état et x une lettre ; on veut connaître l’état q atteint à<br />

partir <strong>de</strong> l’état p par la transition d’étiquette x si cette transition existe.<br />

On rappelle que le cardinal <strong>de</strong> l’alphabet est majoré par une constante (égale à 26).<br />

Caml : Écrire en Caml une fonction nommée etat_suivant telle que si :<br />

• A, <strong>de</strong> type automate, co<strong>de</strong> l’automate A,<br />

• p est un entier codant un état <strong>de</strong> A,<br />

• x est une lettre appartenant à Σ,<br />

alors etat_suivant A p x renvoie un entier codant l’état q tel que (p, x, q) soit<br />

une transition <strong>de</strong> A si cette transition existe et -1 sinon. Indiquer la complexité <strong>de</strong> cette<br />

fonction.<br />

Pascal : Écrire en Pascal une fonction nommée etat_suivant telle que si :<br />

• A, <strong>de</strong> type automate, co<strong>de</strong> l’automate A,<br />

• p, <strong>de</strong> type integer, contient le numéro d’un état <strong>de</strong> A,<br />

• x, <strong>de</strong> type char, contient une lettre appartenant à Σ,<br />

alors etat_suivant(A, p, x) renvoie une valeur <strong>de</strong> type integer contenant<br />

l’état q tel que (p, x, q) soit une transition <strong>de</strong> A si cette transition existe et -1 sinon.<br />

Indiquer la complexité <strong>de</strong> cette fonction.<br />

❒ 13 – Il s’agit <strong>de</strong> déterminer l’état, s’il existe, qui est extrémité du calcul dont<br />

l’origine est l’état initial et dont l’étiquette est un mot donné.<br />

Caml : Écrire en Caml une fonction nommée execution telle que si :<br />

• A, <strong>de</strong> type automate, co<strong>de</strong> l’automate A,<br />

• u, <strong>de</strong> type string, co<strong>de</strong> un mot u sur Σ,<br />

alors execution A u renvoie un entier codant l’état q qui est l’extrémité du calcul<br />

dont l’origine est l’état initial et dont l’étiquette est u, si q existe, et -1 sinon. Indiquer<br />

la complexité <strong>de</strong> cette fonction.<br />

Pascal : Écrire en Pascal une fonction nommée execution telle que si :<br />

• A, <strong>de</strong> type automate, co<strong>de</strong> l’automate A,<br />

• u, <strong>de</strong> type tab_char, contient un mot u sur Σ,<br />

• lu, <strong>de</strong> type integer, contient la longueur <strong>de</strong> u,<br />

alors execution(A, u, lu) renvoie une valeur <strong>de</strong> type integer donnant l’état<br />

q qui est extrémité du calcul dont l’origine est l’état initial et dont l’étiquette est u, si q<br />

existe, et -1 sinon. Indiquer la complexité <strong>de</strong> cette fonction.<br />

❒ 14 – Il s’agit <strong>de</strong> savoir si un mot est reconnu ou non par un automate.<br />

Caml : Écrire en Caml une fonction nommée reconnait telle que si :<br />

• A, <strong>de</strong> type automate, co<strong>de</strong> l’automate A,<br />

• u, <strong>de</strong> type string, co<strong>de</strong> le mot u sur Σ,<br />

alors reconnait A u renvoie le booléen true si le mot u est reconnu par A et<br />

false sinon. Indiquer la complexité <strong>de</strong> cette fonction.<br />

Pascal : Écrire en Pascal une fonction nommée reconnait telle que si :<br />

• A, <strong>de</strong> type automate, co<strong>de</strong> l’automate A,<br />

• u, <strong>de</strong> type tab_char, contient le mot u sur Σ,<br />

• lu, <strong>de</strong> type integer, contient la longueur <strong>de</strong> u,<br />

alors reconnait(A, u, lu) renvoie le booléen true si le mot u est reconnu par<br />

A et false sinon. Indiquer la complexité <strong>de</strong> cette fonction.<br />

Page 10 sur 14

Hooray! Your file is uploaded and ready to be published.

Saved successfully!

Ooh no, something went wrong!