Aller au contenu

Nombre de 1

Nombre de 1⚓︎

On considère un tableau vide ou ne contenant que des 0 et des 1. Ce tableau est trié dans l'ordre croissant et il est possible qu'il ne contienne que des 0 ou que des 1. Combien compte-t-il de 1 ?

Écrire la fonction compte_uns qui prend en paramètre un tel tableau et renvoie le nombre de 1 qu'il contient.

Attention

Certains des tableaux utilisés dans les tests sont très grands. Une méthode avec un coût linéaire sera inefficace face à ceux-ci.

On limite donc le nombre de lectures dans chaque tableau à 500. Passé cette valeur maximale, tout nouvel accès provoquera une erreur.

On rappelle à ce titre que le tableau est trié...

Exemples

Python Console Session
>>> compte_uns([0, 1, 1, 1])
3
>>> compte_uns([0, 0, 0, 1, 1])
2
>>> compte_uns([0] * 200)
0
>>> compte_uns([1] * 300)
300
>>> compte_uns([0] * 200 + [1] * 500)
500
Exercice 1

Compléter le script ci-dessous :

###(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 : 5/5

.128013;xk=/êbC04][peg1-Iw)éiuf.5:r3,(_q+vhzS9a c8nP6doUl2tLOs7yRm050V0o0!0O0w0Y0%0P0Q0Y0O0%0%0e010!0w0n010406050%0x0+0+0O0C0)040M0W0Y0x0 0W0S0P020O0+0n0b0P0*0o190C0H0x0o0%050f16181a1c140n04051H1A1K0f1H140V0w0J0@0_0{0}0_0S0p0x0O0p0o0r0n0)0!0K1j0P0K0w0p0K0Y1:0K0!12050/0h0Y0o1T0`0|011/1;1?1;0!1|1~1`0!0C1I1+0@1f0%0n0O0S0}0Z01201V010y0;0o0S1n0o1`2i2k2p222s1~2v0+2x040a0P0T0C0W0n0W0%0w1i1k0-2g0C0C0o0Q2S1A2z0S1I0f1+2(2c2e2d1{0V2B1W0w0S2u2P1`1Q1S0^212=2@0S0W2{1`0n2X1I2$2(38152j1k2}2q310C190Y1`0O1.2X0y0}030G0G0Q320o1?300W0r0q3z120P0q1A0O393c133b2A3e223g3i3k3m0o3o013q3s3u3w2^3z0r2n040P0Z3F3H2k3J2$2;013O0O3j1I3l0K3n3p3r3t0-3Y313!0D3C0D3*2#3I143.3M0}3;3?053^3`3U3|3X2?3Z3A0k3C0k451B473K3d1U3N0W3h3=3Q3_3S3{3W3~4k403A0A3C0A4q38483c3/4c4A4g3V3}3v4G3y3A0U3C0U4M4s494v4b4x3P3@3R3T4U4j3x3!0(3C0(4%3,4O3L4*3:4,4z4.4B4:4i4F4?3A0R3C0R4{2%4}4u2~504y4d4f4C4h4E4W580r0N3C0N5d3-4P4a5i4-4e4/4D4V3 4Y3z0j120q0j5v5f4Q515k5C5n5E4X3!0q0q5J3E0f3G464|4t5O5j4S5m4;574l3z3$0q3)5!3+5e5(5y4R534T565p5/0q4204625M5`4 5|5B545D4=614n644p5@5$5_4)5h695l555o5F5V4J644L6i4r5%6l3f5P5+6p5T5q0q4!644$6w4N676m6B5}5,5 6r3A0q4^644`6K4(5x686O6a5~6q5U6T5a645c6Y6y6!6N5*6P6D6d4H3z5s645u6/2%1L361A2{2+0V2e2:5y4V2`1R1I350o373I6j1I4V7g2A0w0V0}3r2$5V3Q7n7p6)6F2o2F0o7v6E611`6i6z220d120-0y7i6M2q0t3C7M7G4b0y123t1o0!0o0G0x0S1z6x707S0111040F7R6;3f12290o0O0x7/4~5h7,0u0B7i147(7l1k7u017q3c3!3$5B856R6*3#7y2w7B6_5G8a5@0P8n0P7N7H120w7L828p7*0S7=0O1}7@7_8v8q0}0W120e0e7i8w7:227,0m0l7 82813a3.8c0G7r3A638b7o867w5/420P7z8i5.6`8#8m8o8?8F017I042X0!0x0C0S8L8^0+0w125L8T7`848%872k3!6f8$8.606`4n8,8h8(7C9i7E3G8U7h8W9a8Y884I7t9u9n5G4J9k2G9g6S0r6t3*8@7*8`8t918x8z8B7^983/8P9T5y93959W4 7,0l9O8N8G8I8K8E7*9Y649!7|128S6L825(8X8Z0r6H9f9m8j3!4!9D7Aa08/5G9~8=8?8n8^8`8|8~909-9)3:0h122E9;2q7,7.9_9P047?9Sasaj7}809T9{9w0r6V9 8d5q4^a49F8eaF5@9r3,9`9u9|6,aG8)6`5aaKa69h5GaUaa8M7{7;040-0h1h9(a*228H049,38a)5g2q9/969^8V4PaC9c3A6|aV9A3!5saZaH5/b5a(8^8y042saha_8^a?a^3Ia`4Qal04anaxa;0}aqao3N9Q1~awb0bv7+120ua:a{a=120rbI3/9/5Za 9sb1aSaD5K9yaL6F5IbaaW5GbW2(3G9Kaj8`0t1/1~bN5{7J0oa.0!b;4 a?020Y0!0bbn3,bpb=bh2?bybw9?aAbu997v9|5WbXa!9Gcfb#b76T5Xb)3%abacat931?0o8Dbk7*bmb`9=7-c73:b?b^cA2qa?0IcHbzc5bjbSbEazaibEa?0f0fcL0}9/5?bRaQ9tcdbV8a3l8Xcl5:8g9Ech8e5=9pcpcqad8s8ucxajbgavcwcPbJc8040mcDbgct0wcvcD9$cX01bmc12%c34 a}dcc997cb0Pb20S5V8#c+9za16T8+8-c;6F8;b*cqabbfcFa/cSd3df8Ided80;dad1c2bl12cKdKbO949:dobDcc8(ce9edvbY6ec/a5bb6`0q9ea(b+bE8`4Wc|bodHau8AbBdS7)ay12d6dpc4d9dbdX5ya?bMebdkdZbQd29U129%ef5hdgdebPdm049@4sdpdr6scgd:b%9CdAeAeycodFdGatbideczena+e9e23%dU04eec}bEerd#ejex6T9~d+dB61a3eDb$5Va9dEc_9L123v0%0oeseu5%ewbUb33zaFe%eE6TaJe+c-6Uc@eHd^dLae0.agdObrbtd$ekcCe768bA8CesbHeNbKeTdO12ePcafie!3zaUf1e,6+d.d,d;a%9qaBe}ds6Tb5fCf6b9f5dx6{f88oc`8{fd8 eqdZa~ev3a0f7k717f737c1A0!76f:2.2)e0f-0f741G833/2X0+0G0y0O0d7Z0K631s1u1w1y0Pe`701N3J1H0#1 7e930o0C0P7Y0%0!0P0ngn2Ggs2U2c0:7Ygo1~0@0`0P0-0?d00c0P0J7n1y0z0Pgj0Pe@3t0S783v0x0wgGgcgJ8,1 gU7Y2v0Sgsgbg!1z4V3/1X1Z1#1%1)1.1@261^2yajeXf)7kgP0$1k2X0S0J0Wda0P3=4x0?1Q2X2Z1t2ugs0_0P0Y1j1Zcvgo0V0xgpf_7^gP0ig(gF2O8~0CgA0P0g2c1 gz2R0vgt1ahn3l0h0W0x0^gk0C2?0Q103=1 190w0?0QhJ1ygs2?2R0w3=gtgv0.gG002N0 93e@gCg(3u0z1Lgh04gRd0h;1hhGhIhN0C0/0phM2ug!0xgK0L1jgc0F0v0Jhk1x0Y1~2Gg,gLgN0%0ugd0P7#1 ij2@g%2gg,2u2kg-1xg/8pg;5yg?1!1$1(0)g{251@1_f~9Xf$7Mf*3u040EiAiE7^i9iEg)iIiug.gHiN3ug=2kg@iSg`241=iXg eWehi$h3i1f}h5iA0 1?e@i+1 hh0Kgn0QjhgG0wjj0W0!0W93g.0Obig!gp2M0xiogC3l2O2Q2SgGhugldago05iO4 iQg^iTiVj027j2dLh17hi%0-i)hn0w937Y0Phk2X0@gc0-ih0PiDgO0P0s0YgS001#2Rjv0Y007#0wg.jKi_iPi{iRg_iUi g}iY92j49_jX7fgt0C0v0Q0v0VhM2jgo7#i^2Uk41Yk6jPk9j1iZeg9Zkeh30P0XiE0yhagIjx0JhM1-h7h9hbgD310+0hj*2Uk2ksjMk5jOi~g|kykc5Jj5i(i0ggf}0MgZj}1-1w2Rj%hmhRhTgD0%2k0?0OkPgokO0W0)hM2Uki16b~0Ogs0Q00h+0Pg.gDi5i/1jg*hF7^0QkqkXg(kZkuk#k8k%jSkz5hjVaQkf04h41kgui7l40)gnkrlt5hjNi}lxiWlzk)04f%lDj6k.730.0:0=04.

Crédits⚓︎

Un exercice de Nicolas Revéret