Suites numériques en Python
Première générale, spécialité maths
Suites définies explicitement, à partir d'une fonction: un = f (n)
Exercice 1:
- Qu'affiche le programme suivant ?
def u(n): return 3*n-2 print(u(2)) n=10 print(u(n))
- Modifier le programme précédent pour qu'il calcule les termes de la suite
(un)
définie par l'expression
un = 2n2−1 n2+2Afficher en particulier les termes u10, u100, et u1000.
Qu'observe-t-on pour des valeurs de plus en plus grandes de n ?
Exercice 2:
Afficher la suite des nombres.
- Qu'affiche le programme suivant ?
(Voir le paragraphe boucles sur des entiers du chapitre sur les boucles for) On peut adapter l'affichage des termes en utilisant plutôt:def u(n): return n**2-3 for n in range(10): print(n,u(n))
for n in range(10): print("u(",n,") = ",u(n))
- De la même façon, le programme suivant trace aussi les points correspondants sur un graphique
(Voir éventuellement le paragraphe graphiques avec Python)from pylab import * def u(n): return n**2-3 for n in range(10): plot(n,u(n),'*b') show()
- Modifier le programme précédent pour qu'il affiche et trace les 100 premiers termes de la suite
(un)
définie à la question 2. de l'exercice précédent.
Vers quelle valeur semble tendre les valeurs des termes de la suite lorsqu'on augmente n (et tend vers l'infini) ?
Calcul de seuil
Exercice 3:
Afficher la suite des nombres, jusqu'à un certain point
- On considère la suite (un) définie explicitement par
un = n2 − n + 1
Calculer (sur une feuille) le rang n0 à partir duquel on a, pour tout n ≥ n0, un≥1000 - Qu'affiche le programme suivant ?
(Voir aussi les boucles conditonnellesdef u(n): return n**2-n+1 n=0 while u(n)<1000: print(u(n)) n=n+1 print(n)
while
) - On reprend la suite
(un)
définie à la question 2. de l'exercice 1. :
un = 2n2−1 n2+2
On a vu que cette suite tend vers 2. Déterminer le rang n, à partir duquel un devient supérieur à 1,999 ?
Suites définies par récurrence: un+1 = f (un)
Exercice 4:
- Qu'affiche le programme suivant ?
La fonction définie et utilisée ici s'appelle une fonctions récursive: c'est une fonction qui s'appelle elle-même.def u(n): if n==0: return 2 else: return 3*u(n-1)-2 print(u(0)) print(u(1)) print(u(2)) n=10 print(u(n))
- Modifier le programme précédent pour qu'il calcule les termes de la suite
(un)
définie par u0 = 1 puis par l'expression
un+1 = 2un2+1 un2+1Afficher en particulier les premiers termes jusqu'à u10, puis jusqu'à u30.
- Une autre manière de programmer les calculs des termes d'une suite récurrente est:
qui calcule et affiche ici tous les premiers termes jusqu'à u10.u=1 n=10 for i in range(n): u=(2*u**2+1)/(u**2+1) print(u)
- Utiliser ce programme pour afficher en particulier les termes u10, puis u100 et u1000.
- Comparer l'exécution à celle du programme précédent.
- Qu'observe-t-on pour des valeurs de plus en plus grandes de n ?
- On définit la fonction f telle que
un+1 = f (un).
- Étudier le sens de variation de f.
(voir le paragraphe courbe représentative d'une fonction pour tracer la courbe de cette fonction avec Python) - Montrer que la suite (un) est croissante.
- Montrer que la suite (un) est majorée par 2.
- Étudier le sens de variation de f.
Exercice 5:
On considère la suite
(an) définie par a1 = 0,5
puis par la relation de récurrence
an+1 = 0,5an + 0,3.
- Conjecturer, à l'aide Python, le sens de variation et la limite de cette suite.
- Montrer que, pour tout entier n ≥ 1, on a 0 ≤ un ≤ 0,6.
- Démontrer les conjectures précédentes: la suite (an) est croissante et convergente, et calculer exactement sa limite.
Somme des termes d'une suite
Exercice 6:
- Que calcule le programme suivant:
n=int(input("Entrer n: ")) s=0 for i in range(n+1): s=s+i print("i= ",i, " - s= ",s)
- Modifier le programme précédent pour qu'il calcule, pour un nombre
n
de termes donné (ou demandé à l'utilisateur), les sommes:- S = 1 + 12 + 13 + 14 + 15 + …
- T = 1 + 122 + 132 + 142 + 152 + …
- U = 1 + 121 + 122 + 123 + 124 + …
- Quelles conjectures peut-on faire pour ces trois suites ? lorsque le nombre n de termes augmente indéfiniment ?
Exercice 7:
On considère la suite
(un)
définie par
u0 = 1
et par la relation de récurrence: pour tout entier naturel
n
,
un+1 = f (un),
où la fonction
f est définie sur l'intervalle
[ 0 ; +∞ [
par
f (x) =
5 − 4x + 2
On définit de plus, pour tout entier naturel n, la somme (Sn) par
- Calculer S0, S1 et S2. Donner une valeur approchée des résultats à 10−2 près.
- Compléter le programme Python suivant pour qu'il affiche la somme
Sn
pour la valeur de l'entier
n demandée à l'utilisateur.
u=1 s=u i=0 n=int(input("Entrer un nombre:")) while ... i=i+1 u= ... s= ... print( ... )
Exercice 8:
Une association sportive compte 500 adhérents.
On constate que, chaque mois,
- 5% des adhérents ne renouvellent pas leur adhésion
- 30 nouveaux adhérents s'inscrivent dans l'association
- Écrire un programme qui calcule et affiche le nombre d'adhérents dans l'association mois après mois, pendant 2 ans.
- Calculer le montant total des cotisations perçues en 2 ans.
- Quel devrait être le montant de l'adhésion mensuelle pour que l'association puisse financer complètement une nouvelle installation qui coûte 20 000 euros ?
Un exemple de problème: dynamique de populations
Exercice 9:
- Un village comptait 2000 habitants l'année 2000.
Chaque année depuis, cette population augmente de 3% d'une année à la suivante.
- Écrire un programme qui calcule le nombre d'habitants dans ce village en 2001, puis 2002, puis 2010, puis cette année.
- Modifier le programme précédent pour qu'il détermine en quelle année la population du village aura triplé.
- On observe maintenant des flux de population entre deux villes A et B.
Il y a maintenant 50000 personnes qui habitent dans la ville A et 2000 dans le village B.
Chaque année, 10% de la population de la ville A déménage pour aller habiter dans le village B, tandis que 30% des habitants du village B viennent habiter dans la ville A.
Comment vont évoluer les populations de ces deux villes ?- Écrire un programme qui calcule le nombre d'habitants, année aprés année, dans la ville A et dans le village B. Représenter graphiquement, sur un même graphique, l'évolution de ces populations en fontion de l'année, en rouge pour la ville A et bleu pour B.
- La population de la ville A évolue comme précédemment: 10% des habitants vont chaque année habiter en B.
30% des habitants de B vont encore aussi chaque année se déplacer vers A.
On considère maintenant de plus que, chaque année, 5% des habitants de B vont ailleurs, ni en A ni en B.
Modifier le programme précédent pour rendre compte graphiquement de la nouvelle évolution des populations.
Voir aussi: