Nom Triangulaire – Bac théorique – Section informatique – 2024

Bac Info 24-01-26
20 0

Sujet (Algo et programmation - Bac 2024)

Dans le but d’attribuer des cadeaux à des invités présents dans une soirée, on se propose de choisir les personnes dont le nom est triangulaire et ayant le score le plus élevé. Ces personnes seront déclarées gagnantes.

Un nom est dit triangulaire, si son score est un nombre triangulaire.

Le score d’un nom est la somme des rangs dans l’alphabet de toutes les lettres qui le constituent. Un nombre S est triangulaire s’il existe un entier 𝑛 tel que :

Sachant que les noms des invités sont enregistrés dans le fichier texte "Invites.txt", on procède comme suit pour sélectionner les personnes gagnantes :

- Transférer, à partir du fichier "txt" les noms triangulaires vers un nouveau fichier d’enregistrements nommé "Triangulaires.dat" où chaque enregistrement est constitué de deux champs :

Nom : le nom de la

Score : le score du nom de la

- Afficher les noms des personnes gagnantes (ayant le score le plus élevé).

Travail demandé :

1- Ecrire un algorithme du programme principal en respectant le procédé décrit précédemment et en le décomposant en modules.

2- Ecrire un algorithme pour chaque module envisagé.

 

Solution Algorithmique

Dans cet algorithme, On va utiliser trois fonctions et quatre procédures

- la fonction saisie()

- la procédure remplir_fichier_Invites()

- la fonction test_triangulaire()

- la fonction calcul_score()

- la procédure remplir_fichier_triangulaire()

- la procédure recherche_maxscore_gangnants()

- la procédure afficher_gagnants()

 

Algorithme du programme Principal

Déclaration des objets

Objet Type / Nature
n entier
max_score entier

 

La fonction saisie

Cette fonction permet de saisir et retourner un entier > 0 en contrôlant la validité de la saisie.

Déclaration des objets

Objet Type / Nature
n entier

 

La procédure remplir_fichier_Invites

Cette procédure sert à enregistrer dans le fichier Invites.txt une liste de n invités saisis par l’utilisateur, à raison d’un nom par ligne.

Déclaration des objets

Objet Type / Nature
f fichier
i entier
nom chaîne

 

La fonction test_triangulaire

Cette fonction teste si le score donné est un nombre triangulaire et renvoie vrai si c’est le cas, faux sinon.

Déclaration des objets

Objet Type / Nature
n entier

 

La fonction calcul_score

Cette fonction qui calcule le score d'un nom qui est la somme des positions alphabétiques des lettres du nom (A=1, B=2, ..., Z=26).

Déclaration des objets

Objet Type / Nature
score entier
i entier

 

La procédure remplir_fichier_triangulaire

Cette Procédure crée le fichier binaire "Triangulaires.dat" contenant les invités dont le score est triangulaire.

Déclaration des objets

Objet Type / Nature
f_invite fichier
f_triangle fichier
noms chaîne
nom chaîne
score entier
invite enregistrement

 

La fonction recherche_maxscore_gangnants

Cette fonction recherche le score maximum parmi les invités triangulaires

Déclaration des objets

Objet Type / Nature
f_triangle fichier
max_score entier
invite enregistrement

 

La procédure afficher_gagnants

Cette procédure affiche les gagnants (invités ayant le score maximum).

Déclaration des objets

Objet Type / Nature
f_triangle fichier
invite enregistrement

 

Solution en Python

Exécution du programme

0 commentaire

laisser un commentaire

Veuillez noter s'il vous plaît*

Votre adresse e-mail ne sera pas publiée. Les champs obligatoires sont indiqués avec *

Passion de robotique

Atelier robotique

Construction des robots

Bras robotique

Maison intelligente

But de ce site web

La robotique éducative joue un rôle important dans l'éducation des enfants et des jeunes en les aidant à acquérir des compétences en science et technologie.
Dans ce cadre notre site web représente une excellente ressource pour les parents, les enseignants et les enfants qui souhaitent découvrir la robotique.

Coordonnées

Zaouiet Kontech-Jemmel-Monastir-Tunisie

+216 92 886 231

medaliprof@gmail.com

Photos des articles

Site robotique réalisé par Mohamed Ali Haj Salah - Prof Info