Somme des termes d'une suite mathématique

Soit \((u_n)\) la suite définie pour tout \(n > 0\) par \(u_n = \frac{1}{n}\). On souhaite calculer la somme \(S_n\) des \(n\) premiers termes de cette suite.

Par exemple, la somme des \(70\) premiers termes est :

\[ \begin{align*} S_{70} &=\sum_{k=1}^{70}u_n\\ &=u_1+u_2+\dots+u_{70}\\ &= 1+\frac12+\frac13+\dots+\frac1{70}\\ &\approx 4,832~836~75 \end{align*} \]

Écrire la fonction somme_termes qui calcule la somme \(S_n\) des n premiers termes de \((u_n)\).

On garantit que \(1 \leqslant n \leqslant 10^3\).

Comparaison de nombres flottants

Lorsqu'on écrit a = x ou x est un nombre réel, la valeur de a enregistrée en machine est une valeur approchée de x (quelques fois la valeur exacte). Cette valeur approchée a la forme d'un nombre flottant (le type float en Python). En conséquence, alors que des calculs et des comparaisons peuvent être effectués de manière exacte sur des réels, ils ne le sont que de manière approchée sur leur représentation en machine. On peut donc obtenir par exemple, avec a = x et b = y, l'expression a == b évaluée à True alors que x et y sont différents.

C'est pourquoi les tests ne vérifient pas l'égalité des résultats et des valeurs attendues mais leur proximité.

Ainsi, on peut vérifier que \(\sqrt{2} \approx 1,414214\) en faisantassert abs(1.414214 - sqrt(2)) < 1e-6. Ce test vérifie que les deux valeurs sont proches à \(10^{-6}\) près.

assert ?

Le mot clé assert est utilisé en Python afin de vérifier que des propositions sont vraies.

Ainsi, l'instruction assert 3 + 5*7 == 38 permet de vérifier que l'expression 3 + 5*7 est bien évaluée à 38.

Si c'est le cas, le programme continue de se dérouler normalement. Dans le cas contraire, le programme est interrompu et une erreur est signalée.

La vidéo ne s'affiche pas... ?

Il peut arriver que les vidéos ne s'affichent pas sur des navigateurs basés sur Chrome, ou si un ad-blocker est activé sur le navaigateur. Essayer avec un autre navigateur si vous êtes dans ce cas (FireFox, typiquement), ou désactivez l'ad-blocker.

Exemples
>>> somme_termes(1)
1.0
>>> somme_termes(2)
1.5
>>> somme_termes(3)
1.8333333333333333
>>> somme_termes(70)
4.832836757638071

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
Entrer ou sortir du mode "deux colonnes"
(Alt+: ; Ctrl pour inverser les colonnes)
Entrer ou sortir du mode "plein écran"
(Esc)
Tronquer ou non le feedback dans les terminaux (sortie standard & stacktrace / relancer le code pour appliquer)
Si activé, le texte copié dans le terminal est joint sur une seule ligne avant d'être copié dans le presse-papier
Évaluations restantes : 10/10

.128013s3o_bcdufvg/0ly napSr1me,(P2=4:+twki5h)6050h0y0H0s0K0o0b0q0g0o0s0b0b0D010H0K0t010406050b0i0x0x0s0v0p040u0d0o0i0)0d0r050m0:0=0@0_0.0t041219051c0m1c1e190.0h0K0k0X0Z0#0%0M0K0l0M0o1s0M0H0,050S0f0o0y1n0!0$011r1t1v1t0H1B1D1z0H0f0d0h0_1A0v1a0H0M0X0|0b0t0s0r0%0C011F1p010j0U0y0r0s0x0y1z1%1)1.1H1;1D1@1_0,0a0q0B0v0d0t0d0b0K0 0r0q0Q1#0v0v0y0g2e121|0r1a0m1Z2r0H1X1W1Y0h1~0%1v0r1?2b1z1k1m0Y1G2B0K2D0r1T1l1z0t2k1a2p2r2V0/1(2f2J1/2O0v0?0o0,0w2o2Z0-2Y1}2#1H2%2)0,0C2-1)2/2p2A012@0s2*040c2{2q0.2~2=0%31330E362}2Z2 3c0,0L3f383h3a300d2(320,0O3f1b2T122H2u0h2y2 0g1T1`1a3A1d3y2X132.053F0Q2U3o1o1H0J0,0Q0j3w393U0%0I0,0q3!3T2K300j0,0b0d0=0y0e0H0y2(0y0b3+2;3$010+040A3~2!400r0,113N2|2:463-420N0F3m0q4k3*3#3-48043;3?3f4m3,1/0d0,0D4t4d2 0x0K0,0n4j4l4B3p3W040j3r4A4n2$0,0J4P4v1H0d3(042M4U3 4o0f0,0v1)0l0y452 42444b2q4J404D2+4.3p420z4#4e4R044a2V4u4$4w0,0G4 4C4E042,4=3S561H4g4i5f064l5n55502?3:3=1_5a3p4x044z5f5p3i5s4s5A4@3-5x595F4Q1H4_5d5v405x0m5P4o4S3m5m4I5L0%4L2k0H0i0v532.5B3p4p4r5u5l123Q0y2r2S5@3z1l3B2u2w2s1S1U2u0s1C5`0m3A0.670R0T0V04.

###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
Entrer ou sortir du mode "deux colonnes"
(Alt+: ; Ctrl pour inverser les colonnes)
Entrer ou sortir du mode "plein écran"
(Esc)
Tronquer ou non le feedback dans les terminaux (sortie standard & stacktrace / relancer le code pour appliquer)
Si activé, le texte copié dans le terminal est joint sur une seule ligne avant d'être copié dans le presse-papier
Évaluations restantes : 10/10

.128013s3o_bcdufvg/0ly napSr1me,(P2=4:+twki5h)6050h0y0H0s0K0o0b0q0g0o0s0b0b0D010H0K0t010406050b0i0x0x0s0v0p040u0d0o0i0)0d0r050m0:0=0@0_0.0t041219051c0m1c1e190.0h0K0k0X0Z0#0%0M0K0l0M0o1s0M0H0,050S0f0o0y1n0!0$011r1t1v1t0H1B1D1z0H0f0d0h0_1A0v1a0H0M0X0|0b0t0s0r0%0C011F1p010j0U0y0r0s0x0y1z1%1)1.1H1;1D1@1_0,0a0q0B0v0d0t0d0b0K0 0r0q0Q1#0v0v0y0g2e121|0r1a0m1Z2r0H1X1W1Y0h1~0%1v0r1?2b1z1k1m0Y1G2B0K2D0r1T1l1z0t2k1a2p2r2V0/1(2f2J1/2O0v0?0o0,0w2o2Z0-2Y1}2#1H2%2)0,0C2-1)2/2p2A012@0s2*040c2{2q0.2~2=0%31330E362}2Z2 3c0,0L3f383h3a300d2(320,0O3f1b2T122H2u0h2y2 0g1T1`1a3A1d3y2X132.053F0Q2U3o1o1H0J0,0Q0j3w393U0%0I0,0q3!3T2K300j0,0b0d0=0y0e0H0y2(0y0b3+2;3$010+040A3~2!400r0,113N2|2:463-420N0F3m0q4k3*3#3-48043;3?3f4m3,1/0d0,0D4t4d2 0x0K0,0n4j4l4B3p3W040j3r4A4n2$0,0J4P4v1H0d3(042M4U3 4o0f0,0v1)0l0y452 42444b2q4J404D2+4.3p420z4#4e4R044a2V4u4$4w0,0G4 4C4E042,4=3S561H4g4i5f064l5n55502?3:3=1_5a3p4x044z5f5p3i5s4s5A4@3-5x595F4Q1H4_5d5v405x0m5P4o4S3m5m4I5L0%4L2k0H0i0v532.5B3p4p4r5u5l123Q0y2r2S5@3z1l3B2u2w2s1S1U2u0s1C5`0m3A0.670R0T0V04.