Empaqueter

On dispose d’un ensemble d’objets dont on connaît, pour chacun, la masse. On souhaite ranger l’ensemble de ces objets dans des boites identiques de telle manière que la somme des masses des objets contenus dans une boîte ne dépasse pas la capacité c de la boîte. On souhaite utiliser le moins de boîtes possibles pour ranger cet ensemble d’objets.

Pour résoudre ce problème, on utilisera un algorithme glouton consistant à placer chacun des objets dans la première boîte où cela est possible.

Par exemple, pour ranger dans des boîtes de capacité c = 5 un ensemble de trois objets dont les masses sont représentées en Python par la liste [1, 5, 2], on procède de la façon suivante :

  • Le premier objet, de masse 1, va dans une première boite.
  • Le deuxième objet, de masse 5, ne peut pas aller dans la mĂŞme boite que le premier objet car cela dĂ©passerait la capacitĂ© de la boite. On place donc cet objet dans une deuxième boĂ®te.
  • Le troisième objet, de masse 2, va dans la première boĂ®te.

On a donc utilisé deux boîtes de capacité c = 5 pour ranger les 3 objets.

Compléter la fonction Python empaqueter(liste_masses, c) suivante pour qu’elle renvoie le nombre de boîtes de capacité c nécessaires pour empaqueter un ensemble d’objets dont les masses sont contenues dans la liste liste_masses.

Exemples

Python Console Session
>>> empaqueter([1, 2, 3, 4, 5], 10)
2
>>> empaqueter([1, 2, 3, 4, 5], 5)
4
>>> empaqueter([7, 6, 3, 4, 8, 5, 9, 2], 11)
5
Compléter le code 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

.128013l(9î _4:;=vm26j-uS8wRs3/]+fr7gebh[pPicé05qa,onkyd1x)t050X0F0#0R0L0b0w0f0M0b0R0w0w0k010#0L0J010406050w0r0m0m0R0C0W040s0T0b0r0_0T0U050y101214160~0J04051m1f1p0y1m0~0X0L0l0.0:0=0@0:0U0E0r0R0E0F0q0J0W0#0H1d0f0H0L0E0H0b1R0H0#0|050)0G0b0F1y0;0?011Q1S1U1S0#1!1$1Y0#0C1n1M0.190w0J0R0U0@0n011(1A010B0+0F0U0R0m0F1Y1}1 241*271$2a2c0|0a0f0K0C0T0J0T0w0L1c0U0f0%1{0C0C0F0M2x1f2f0U1n0y1M2K1@1_1^1Z0X2h1B0L0U292u1Y1v1x0/1)2U2W0U0T2!1Y0J2D1n2I2K2;0 1~2y2$252*0C130b1Y0R1P2D0B0@030g0g0M2+0F1U2)0T0q0Y3f0|0f0Y1f0R2=2^0}2@2g2`1*2|2~30320F340136383a3c2X3f0q22040f0n3l3n1 3p2I2T013u0R2 1n310H333537390%3E2*3G0x3i0x3M2H3o0~3Q3s0@3T3V053X3Z3A3#3D2V3F3g0h3i0h3.1g3:3q2_1z3t0T2}3U3w3Y3y3!3C3%403)3g0P3i0P462;3;2^3R3^4g3|3B3$3b4m3e3g0o3i0o4s483=4b3@4d3v3W3x3z4A3 3d3G0D3i0D4J3O4u3r4M3S4O4f4Q4h4S3~4l4V3g0t3i0t4!2J4$4a2%4)4e3_3{4i3}4k4C4;0q0d3i0d4_3P4v3?4~4P3`4R4j4B3(4E3f0O0|0Y0O5b4{4w4*505i535k4D3G0Y0Y5p3k0y3m3/4#495u4 4y524T4:413f3I0Y3L5G3N4`5K5e4x4,4z4/555R0Y3+045+5s5Z4(5#5h4-5j4U5*435-455W5I5Y4L4}5=514.545l5B4p5-4r5~475J612{5v5N655z560Y4G5-4I6c2?1s2/1f2!2N0X1_2S5e4B2Z1w1n2.0F2:3o5 1n4B6H2g0L0X0@372I5B3w6O6Q665A3g5D0f2l0F6W6k5*1Y5~6f1*0V0|0%0B6J5:4}0u3i6?6-3@0B0|0F0m1~0Q0r0(0F0C6{5d4(0{040c784%620|1U0w0#0F0g130=0F0w7e4|257b0S6J0f6@2{0|0M7r3R7b0!0i6J0~6d2J5K6V016R2^3G3I5h7M5(673g226#2b6%7N6X567R6,796^3i0f7-7C5e0w0X0|02730T0#0j7@0r7_7{7^7`0v290l0T0L1%1$6#0T0m0G2D0f0m2V0L2~2z1%0G0T0e7k0-0U0N0M7p0w0*2D0-2t0r777J3p8B7L6P7#6S3g5,7S8F7U6Y0q3+7Y2c6(5_4n8O6+5H6|017;7,7-7072747k0C0f1$0-0T0G0p0(0-2A0:8,0L7j878`7k7m1)7p0S0f8u0M0H1 0#7H7C7T0g8H0q5{8K8S5Q8U438Q7!8M569f7)7f258!3J7-0f731%950R9x0f8l8n1%0J0F1b1{0U7k0U0L8+0R0r8e0R0Z8h110.0f0V0+0T0E0C2b2c0w7|7~9*7`9,0j998D3Q9b9d699g7#6)8U4p9l9h5)9|8W8C2?9=8L9c7P4F6Ua69{5m4G9~9`8Tada29v7x8Y0U0|1e8Bal7*250T0|0k7w7y3t0G7h297/7a0|7d9;as3t7h8}7l7n0w7paD4}7E9:a44v9?a80q4X4Q9bac4W236$9 7VaYaj9vay3@ao0G0g8l2waPaqa/01au04awa`8Y8f0|5r8B7IaU6Na69d4?a!abah3G4?af9n5Rbb3Maka{an04a@8oax8Ya}a 2;ar9r1*7b0IbsaI0@b204b4bwa{6/040B4dbCbya:040gbO7s1*0T6_042VbT4waA049$1D0FaQ7taFb+aJ04apb7bU0@aSb0bD017b0zaT6Ia56W9d58bca*8N58bh7$5Rc3bla.8YbKbM8AbIam0|aNb*b_bPa|bXbZcnb?3SaK8{8 7o7qaHco7b7Gaqb6b aVb9aX5qaac56l5oc8a$6Z5o2K3makbmcjbYb!5ebucZ4(bFbH48cA2yaW1 5B5Dc4ag9i5m5Ca(7ZcM5*c:cccVbxctbK0u1Q1$c$7gcYcs3Ra}020b7`d67zb:a=bqa_cib`bW0|1 0Xdfb/djczb=7D0|bBc+4w0|0Lb.b@0|b}d9c!0|0AdrbQcldLa|7?0EdedH5;7AdDb{0|cDbwcF3O8Ec1cJ7R31a#be6Z7Xa)c=a0c@7(cUc cVbndBdOc#dTd7dCd atdJdObF5F4t9acIc.6Z8Jd+bdc?5B8Pd:bi8U5+a-c bJdB6=e2b/e1dlcobubv3od0dAdha?85brdz5ecCb~d$c08GcJ9feec{el9kejc9eRend_7.cX0UdieEdkeza{d~evctboe!eDa^due(bte4esbE0L5peJ7KeL7Oeb3f9^ePd;a+0Y9}eTcQf1eWcWb`bodtdWbAdWboeucGcBdFd}avdOfee$e;eKb`fheGdUd8dveHfne^dP04dKfDbodNcEe9d(f06mcLf48NfOcPd-3f6nc~eA5ebK2D0#8zb;e=fda;e/eFe88D0y6L1q6t0y6v1f0#6xf_2Q2L0R1#6G6u6D7I0%0)0+0w04.