Agence Immobilière
D’après Baccalauréat Session 2021(sujet 0 n°3)
Une agence immobilière développe un programme pour gérer les biens immobiliers qu’elle propose à la vente.
Dans ce programme, pour modéliser les données de biens immobiliers, on définit une classe Bim avec les attributs suivants :
ntde typestrreprésente la nature du bien (appartement, maison, bureau,commerces, … ) ;sfde typefloatest la surface du bien ;pmde typefloatest le prix moyen par m² du bien qui dépend de son emplacement.
La classe Bim possède une méthode estim_prix qui renvoie une estimation du prix du bien. Le code (incomplet) de la classe Bim est donné ci-dessous :
class Bim:
def __init__(self, nature, surface, prix_moy):
...
def estim_prix(self):
return self.sf * self.pm
Bim.
On exécute l’instruction suivante :
b1 = Bim('maison', 70.0, 2000.0)
b1.estim_prix() ? Préciser le type de la valeur renvoyée.
On souhaite affiner l’estimation du prix d’un bien en prenant en compte sa nature :
- pour un bien dont l’attribut
ntest'maison'la nouvelle estimation du prix est le produit de sa surface par le prix moyen par m² multiplié par 1,1 ; - pour un bien dont l’attribut
ntest'bureau'la nouvelle estimation du prix est le produit de sa surface par le prix moyen par m² multiplié par 0,8 ; - pour les biens d’autres natures, l’estimation du prix ne change pas.
estim_prix afin de prendre en compte ce changement de calcul.
nb_maison(lst) qui prend en argument une liste Python de biens immobiliers de type Bim et qui renvoie le nombre d’objets de nature 'maison' contenus dans la liste lst.
Pour une recherche efficace des biens immobiliers selon le critère de leur surface, on stocke les objets de type Bim dans un arbre binaire de recherche, nommé abr. Pour tout nœud de cet arbre :
- tous les objets de son sous-arbre gauche ont une surface inférieure ou égale à la surface de l’objet contenue dans ce nœud ;
- tous les objets de son sous-arbre droit ont une surface strictement supérieure à la surface de l’objet contenue dans ce nœud.
L’objet abr dispose des méthodes suivantes :
abr.est_vide(): renvoieTruesiabrest vide etFalsesinon.abr.get_v(): renvoie l’élément (de typeBim) situé à la racine deabrsiabrn’est pas vide etNonesinon.abr.get_g(): renvoie le sous-arbre gauche deabrsiabrn’est pas vide etNonesinon.abr.get_d(): renvoie le sous-arbre droit deabrsiabrn’est pas vide etNonesinon.
Dans cette question, on suppose que l’arbre binaire abr a la forme ci-dessous :

b1, b2, b3, b4, b5, b6 triée dans l’ordre croissant de leur surface.
contient donnée ci-dessous, qui prend en arguments un nombre surface de type float et un arbre binaire de recherche abr contenant des éléments de type Bim ordonnés selon leur attribut de surface sf. La fonction contient(surface, abr) renvoie True s’il existe un bien dans abr d’une surface supérieure ou égale à surface et False sinon.def contient(surface, abr):
if abr.est_vide():
return False
elif abr.get_v().sf >= ......... :
return True
else:
return contient( surface , ......... )
