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

.1280133=hOky:4CwP8c0pU/uob[+em7IĂ©-5)](l,Sg9aR; irv.tLzx_16fsn2dĂŞq050)0x0U0M0Q0H0$0P0n0H0M0$0$0c010U0Q0p010406050$0s0y0y0M0R0g040J0t0H0s0 0t0%0P020M0y0p0O0P0N0x190R0+0s0x0$050r16181a1c140p04051H1A1K0r1H140)0Q0S0@0_0{0}0_0%0K0s0M0K0x0C0p0g0U0d1j0P0d0Q0K0d0H1:0d0U12050/0u0H0x1T0`0|011/1;1?1;0U1|1~1`0U0R1I1+0@1f0$0p0M0%0}0(01201V010#0;0x0%1n0x1`2i2k2p222s1~2v0y2x040a0P0l0R0t0p0t0$0Q1i1k0-2g0R0R0x0n2S1A2z0%1I0r1+2(2c2e2d1{0)2B1W0Q0%2u2P1`1Q1S0^212=2@0%0t2{1`0p2X1I2$2(38152j1k2}2q310R190H1`0M1.2X0#0}030Y0Y0n320x1?300t0C0Z3z120P0Z1A0M393c133b2A3e223g3i3k3m0x3o013q3s3u3w2^3z0C2n040P0(3F3H2k3J2$2;013O0M3j1I3l0d3n3p3r3t0-3Y313!0b3C0b3*2#3I143.3M0}3;3?053^3`3U3|3X2?3Z3A0i3C0i451B473K3d1U3N0t3h3=3Q3_3S3{3W3~4k403A0D3C0D4q38483c3/4c4A4g3V3}3v4G3y3A0!3C0!4M4s494v4b4x3P3@3R3T4U4j3x3!0z3C0z4%3,4O3L4*3:4,4z4.4B4:4i4F4?3A0m3C0m4{2%4}4u2~504y4d4f4C4h4E4W580C0L3C0L5d3-4P4a5i4-4e4/4D4V3 4Y3z0o120Z0o5v5f4Q515k5C5n5E4X3!0Z0Z5J3E0r3G464|4t5O5j4S5m4;574l3z3$0Z3)5!3+5e5(5y4R534T565p5/0Z4204625M5`4 5|5B545D4=614n644p5@5$5_4)5h695l555o5F5V4J644L6i4r5%6l3f5P5+6p5T5q0Z4!644$6w4N676m6B5}5,5 6r3A0Z4^644`6K4(5x686O6a5~6q5U6T5a645c6Y6y6!6N5*6P6D6d4H3z5s645u6/2%1L361A2{2+0)2e2:5y4V2`1R1I350x373I6j1I4V7g2A0Q0)0}3r2$5V3Q7n7p6)6F2o2F0x7v6E611`6i6z220f120-0#7i6M2q0k3C7M7G4b0#123t1o0U0x0Y0s0%1z6x707S0111040G7R6;3f12290x0M0s7/4~5h7,0E0h7i147(7l1k7u017q3c3!3$5B856R6*3#7y2w7B6_5G8a5@0P8n0P7N7H120Q7L828p7*0%7=0M1}7@7_8v8q0}0t120c0c7i8w7:227,0v0F7 82813a3.8c0Y7r3A638b7o867w5/420P7z8i5.6`8#8m8o8?8F017I042X0U0s0R0%8L8^0y0Q125L8T7`848%872k3!6f8$8.606`4n8,8h8(7C9i7E3G8U7h8W9a8Y884I7t9u9n5G4J9k2G9g6S0C6t3*8@7*8`8t918x8z8B7^983/8P9T5y93959W4 7,0F9O8N8G8I8K8E7*9Y649!7|128S6L825(8X8Z0C6H9f9m8j3!4!9D7Aa08/5G9~8=8?8n8^8`8|8~909-9)3:0u122E9;2q7,7.9_9P047?9Sasaj7}809T9{9w0C6V9 8d5q4^a49F8eaF5@9r3,9`9u9|6,aG8)6`5aaKa69h5GaUaa8M7{7;040-0u1h9(a*228H049,38a)5g2q9/969^8V4PaC9c3A6|aV9A3!5saZaH5/b5a(8^8y042saha_8^a?a^3Ia`4Qal04anaxa;0}aqao3N9Q1~awb0bv7+120Ea:a{a=120CbI3/9/5Za 9sb1aSaD5K9yaL6F5IbaaW5GbW2(3G9Kaj8`0k1/1~bN5{7J0xa.0Ub;4 a?020H0U0Obn3,bpb=bh2?bybw9?aAbu997v9|5WbXa!9Gcfb#b76T5Xb)3%abacat931?0x8Dbk7*bmb`9=7-c73:b?b^cA2qa?0wcHbzc5bjbSbEazaibEa?0r0rcL0}9/5?bRaQ9tcdbV8a3l8Xcl5:8g9Ech8e5=9pcpcqad8s8ucxajbgavcwcPbJc8040vcDbgct0QcvcD9$cX01bmc12%c34 a}dcc997cb0Pb20%5V8#c+9za16T8+8-c;6F8;b*cqabbfcFa/cSd3df8Ided80;dad1c2bl12cKdKbO949:dobDcc8(ce9edvbY6ec/a5bb6`0Z9ea(b+bE8`4Wc|bodHau8AbBdS7)ay12d6dpc4d9dbdX5ya?bMebdkdZbQd29U129%ef5hdgdebPdm049@4sdpdr6scgd:b%9CdAeAeycodFdGatbideczena+e9e23%dU04eec}bEerd#ejex6T9~d+dB61a3eDb$5Va9dEc_9L123v0$0xeseu5%ewbUb33zaFe%eE6TaJe+c-6Uc@eHd^dLae0.agdObrbtd$ekcCe768bA8CesbHeNbKeTdO12ePcafie!3zaUf1e,6+d.d,d;a%9qaBe}ds6Tb5fCf6b9f5dx6{f88oc`8{fd8 eqdZa~ev3a0r7k717f737c1A0U76f:2.2)e0f-0r741G833/2X0y0Y0#0M0f7Z0d631s1u1w1y0Pe`701N3J1H0V1 7e930x0R0P7Y0$0U0P0pgn2Ggs2U2c0:7Ygo1~0@0`0P0-0?d00X0P0S7n1y0T0Pgj0Pe@3t0%783v0s0QgGgcgJ8,1 gU7Y2v0%gsgbg!1z4V3/1X1Z1#1%1)1.1@261^2yajeXf)7kgP0e1k2X0%0S0tda0P3=4x0?1Q2X2Z1t2ugs0_0P0H1j1Zcvgo0)0sgpf_7^gP0jg(gF2O8~0RgA0P0*2c1 gz2R0Bgt1ahn3l0u0t0s0^gk0R2?0n103=1 190Q0?0nhJ1ygs2?2R0Q3=gtgv0.gG002N0 93e@gCg(3u0T1Lgh04gRd0h;1hhGhIhN0R0/0KhM2ug!0sgK0W1jgc0G0B0Shk1x0H1~2Gg,gLgN0$0Egd0P7#1 ij2@g%2gg,2u2kg-1xg/8pg;5yg?1!1$1(0gg{251@1_f~9Xf$7Mf*3u040IiAiE7^i9iEg)iIiug.gHiN3ug=2kg@iSg`241=iXg eWehi$h3i1f}h5iA0 1?e@i+1 hh0dgn0njhgG0Qjj0t0U0t93g.0Mbig!gp2M0siogC3l2O2Q2SgGhugldago05iO4 iQg^iTiVj027j2dLh17hi%0-i)hn0Q937Y0Phk2X0@gc0-ih0PiDgO0P0A0HgS001#2Rjv0H007#0Qg.jKi_iPi{iRg_iUi g}iY92j49_jX7fgt0R0B0n0B0)hM2jgo7#i^2Uk41Yk6jPk9j1iZeg9Zkeh30P0qiE0#hagIjx0ShM1-h7h9hbgD310y0uj*2Uk2ksjMk5jOi~g|kykc5Jj5i(i0ggf}0JgZj}1-1w2Rj%hmhRhTgD0$2k0?0MkPgokO0t0ghM2Uki16b~0Mgs0n00h+0Pg.gDi5i/1jg*hF7^0nkqkXg(kZkuk#k8k%jSkz5hjVaQkf04h41kgui7l40ggnkrlt5hjNi}lxiWlzk)04f%lDj6k.730.0:0=04.

Crédits⚓︎

Un exercice de Nicolas Revéret