Diverses piles (POO)

Un exercice : deux versions

Cet exercice sur les piles est proposé en deux versions :

On s'intéresse sur cette page au type abstrait de données « Pile » que l'on représente à l'aide d'une classe Pile dont on fournit le code ci-dessous.

La classe Pile
class Pile:
    def __init__(self):
        """Initialise une pile vide"""
        self.valeurs = []

    def est_vide(self):
        """Renvoie un booléen : la pile est-elle vide ?"""
        return len(self.valeurs) == 0

    def empile(self, element):
        """Empile un élément au sommet de la pile"""
        self.valeurs.append(element)

    def depile(self):
        """
        Dépile un élément au sommet et le renvoie.
        Provoque une erreur si la pile est vide.
        """
        if self.est_vide():
            raise ValueError("Erreur, pile vide")
        else:
            return self.valeurs.pop()

    def __repr__(self):
        """Affiche la pile, en indiquant le sommet"""
        return f"| {' | '.join([str(x) for x in self.valeurs])} | <- sommet"

    def __eq__(self, autre):
        """
        Détermine si cette pile et l'autre sont égales
        (mêmes valeurs, dans le même ordre)
        """
        return self.valeurs == autre.valeurs

Cette classe possède deux méthodes spéciale __repr__ et __eq__ qui permettent :

  • d'afficher le contenu de la pile (__repr__) ;
  • de tester l'égalité entre la pile étudiée et une autre pile passée en paramètre (__eq__).

Les lignes ci-dessous présentent un exemple d'utilisation. On prendra soin, dans les différents exercices, de n'utiliser que les méthodes présentées ci-dessous.

Utilisation
>>> p = Pile()    # création d'une pile vide
>>> p.est_vide()  # la pile est-elle vide ? -> Oui
True
>>> p.empile(0)   # empile 0 dans la pile
>>> p.est_vide()  # la pile est-elle vide ? -> Non
False
>>> p.empile(1)   # empile 0 dans la pile
>>> p             # affichage du contenu de p
| 0 | 1 | <- sommet
>>> p.depile()    # dépile une valeur
1
>>> p
| 0 | <- sommet
>>> q = Pile()
>>> q.empile(1)
>>> q
| 1 | <- sommet
>>> p == q  # les piles p et q sont-elles égales ? -> Non
False

Les exercices ci-dessous sont indépendants. Ils sont néanmoins présentés dans un certain ordre permettant d'aborder successivement plusieurs techniques.

Jouons le jeu !

Ces exercices visent à utiliser certaines techniques classiques liées aux piles. Il est donc demandé de les traiter en se limitant à l'utilisation des méthodes la classe Pile.

Il est en particulier interdit d'accéder directement à l'attribut valeurs.

Accéder ou modifier cet attribut fera échouer les tests secrets.

Calculer la taille d'une pile

Écrire la fonction taille qui prend en paramètre une pile et renvoie son nombre d'éléments.

A l'issue du traitement, la pile doit avoir retrouvé son état initial.

>>> p = Pile()
>>> taille(p)
0
>>> p.empile("a")
>>> p.empile("b")
>>> taille(p)
2
Aide

On pourra utiliser une pile annexe.

Etape 1

Etape 2

Etape 3

Etape 4

###(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

.1280135tf4)+2r3sao iug0x8m1P6pnl7h.e=cy:v9(wS/b_dk050R0E0c0l0o0A0k0n0G0A0l0k0k0F010c0o0y010406050k0p0u0u0l0i0H040N0m0A0p0-0m0z050O0@0_0{0}0=0y04161d051g0O1g1i1d0=0R0o0J0#0%0)0+0C0o0q0C0A1w0C0c0:050W0P0A0E1r0(0*011v1x1z1x0c1F1H1D0c0P0m0R0}1E0i1e0c0C0#100k0y0l0z0+0h011J1t010d0Y0E0z0l0u0E1D1+1-1=1L1^1H1{1}0:0a0n0w0i0m0y0m0k0o130z0n0U1)0i0i0E0G2i16200z1e0O1%2v0c1#1!1$0R220+1z0z1`2f1D1o1q0$1K2F0o2H0z1X1p1D0y2o1e2t2v2Z0?1,2j2N1?2S0i0`0A0:0v2s2%0;2$212)1L2+2-0:0h2;1-2?2t2E012{0l2.040j2 2u0=322_0+35370e3a312%333g0:0b3j3c3l3e340m2,360:0x3q2@2(1s2`3v2|040B3A3d3D3f3F3x040t3J3s3L3u3w370K3j1f2X162L2y0R2C330G1X1~1e3$1h3!2#172=053+0U2Y3S2O010S0:0U0d3Y3K3}0M0:0n433|2*0d0:0W0Y1H492^3T0/040L4h3C3}0z0:0y4n334k0f0I3q0n4z48442*0:1-2H0s0E3j4B4a1L0m0:0F4J3B3m0:0w1_4t3t4k0L0f4y4A4R3t4q040c4Q4C4M4O4,4L0+0u0o0:0r4#4z4%3T3 040M1v4g3?304K4i3}0m46042S4+532u554o4D044s5d3{561?4N040D4W3T4)0E0k0c0Q0J0o0U5r3}4Y4w4`4A4{4-3f4E0z4G4I5k4|570:5q5O5I340:0E0u0y4V5T4;014Y5B5h5j2#5U5o5S5,5$4)0U5Z525:5m1L5D4!5k065G5G5P5h5c2Z5f335o4P5k664(4d4:5`0+5o0g6e5g1L4?2/5F621L4~505!656p6g595b6j4S044F0E4H5)4.5p6F5J045u5w5y5A5#6f5%0:4Z4x5~604$5U4)5+3@5-5R6I5V6K5Y6t6#5$5(6P6k6J6C6E6:676%6^6c045?6,306v6R4l0f5}2Z5 6X5$4~2o0c0p0i156a714)642=0=0O3_0E2v2W7o3#1p3%2y2A2w1W1Y2y0l1G7r0O3$7l0U4e0Z04.

###(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

.1280135tf4)+2r3sao iug0x8m1P6pnl7h.e=cy:v9(wS/b_dk050R0E0c0l0o0A0k0n0G0A0l0k0k0F010c0o0y010406050k0p0u0u0l0i0H040N0m0A0p0-0m0z050O0@0_0{0}0=0y04161d051g0O1g1i1d0=0R0o0J0#0%0)0+0C0o0q0C0A1w0C0c0:050W0P0A0E1r0(0*011v1x1z1x0c1F1H1D0c0P0m0R0}1E0i1e0c0C0#100k0y0l0z0+0h011J1t010d0Y0E0z0l0u0E1D1+1-1=1L1^1H1{1}0:0a0n0w0i0m0y0m0k0o130z0n0U1)0i0i0E0G2i16200z1e0O1%2v0c1#1!1$0R220+1z0z1`2f1D1o1q0$1K2F0o2H0z1X1p1D0y2o1e2t2v2Z0?1,2j2N1?2S0i0`0A0:0v2s2%0;2$212)1L2+2-0:0h2;1-2?2t2E012{0l2.040j2 2u0=322_0+35370e3a312%333g0:0b3j3c3l3e340m2,360:0x3q2@2(1s2`3v2|040B3A3d3D3f3F3x040t3J3s3L3u3w370K3j1f2X162L2y0R2C330G1X1~1e3$1h3!2#172=053+0U2Y3S2O010S0:0U0d3Y3K3}0M0:0n433|2*0d0:0W0Y1H492^3T0/040L4h3C3}0z0:0y4n334k0f0I3q0n4z48442*0:1-2H0s0E3j4B4a1L0m0:0F4J3B3m0:0w1_4t3t4k0L0f4y4A4R3t4q040c4Q4C4M4O4,4L0+0u0o0:0r4#4z4%3T3 040M1v4g3?304K4i3}0m46042S4+532u554o4D044s5d3{561?4N040D4W3T4)0E0k0c0Q0J0o0U5r3}4Y4w4`4A4{4-3f4E0z4G4I5k4|570:5q5O5I340:0E0u0y4V5T4;014Y5B5h5j2#5U5o5S5,5$4)0U5Z525:5m1L5D4!5k065G5G5P5h5c2Z5f335o4P5k664(4d4:5`0+5o0g6e5g1L4?2/5F621L4~505!656p6g595b6j4S044F0E4H5)4.5p6F5J045u5w5y5A5#6f5%0:4Z4x5~604$5U4)5+3@5-5R6I5V6K5Y6t6#5$5(6P6k6J6C6E6:676%6^6c045?6,306v6R4l0f5}2Z5 6X5$4~2o0c0p0i156a714)642=0=0O3_0E2v2W7o3#1p3%2y2A2w1W1Y2y0l1G7r0O3$7l0U4e0Z04.
Renverser les deux valeurs au sommet

Écrire la fonction renverse_deux qui prend en paramètre une pile et échange l'ordre des deux valeurs au sommet.

La transformation se fait en place : on modifie directement sur la pile et il est donc inutile de la renvoyer.

On garantit que la pile compte au moins deux éléments.

>>> p = Pile()
>>> p.empile("a")
>>> p.empile("b")
>>> p.empile("c")
>>> p
| a | b | c | <- sommet
>>> renverse_deux(p)
>>> p
| a | c | b | <- sommet

###(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

.12801354tf)2r3sao iugxm1Ppnlh.e=cy:v(wS/b_dk050L0z0d0k0n0w0j0m0B0w0k0j0j0A010d0n0u010406050j0o0r0r0k0h0C040H0l0w0o0%0l0v050I0.0:0=0@0,0u041017051a0I1a1c170,0L0n0E0V0X0Z0#0x0n0p0x0w1q0x0d0*050Q0J0w0z1l0Y0!011p1r1t1r0d1z1B1x0d0J0l0L0@1y0h180d0x0V0`0j0u0k0v0#0g011D1n010e0S0z0v0k0r0z1x1#1%1,1F1/1B1=1@0*0a0m0t0h0l0u0l0j0n0}0v0m0O1Z0h0h0z0B2c101`0v180I1X2p0d1V1U1W0L1|0#1t0v1;291x1i1k0W1E2z0n2B0v1R1j1x0u2i182n2p2T0-1$2d2H1-2M0h0;0w0*0s2m2X0+2W1{2Z1F2#2%0*0g2+1%2-2n2y012=0k2(040i2_2o0,2|2:0#2 310c342{2X2}3a0*0b3d192R102F2s0L2w2}0B1R1^183o1b3m2V112,053t0O2S3f38010M0*0O0e3k371m1F0G0*0m3O3H3Q390e0*2i0v0E0z0h0j0z0K0O0o0q3V2/3X010)040F3:2Y3=0v0*0u3`2}3@0f0D3d060m473U3P2I2~0*0k3d493W4b0l0*0A4f2.3{4b3}043 3B2`4n2}4j040y403I4q0O0u1:4A3=3@0F0f45484g3;4p0*0J4m4a1-4x4l4t2o4N4o2!3~4G4i0*4z4X3G4O4#044D4F4+4v3I4I4K4+46484?3|4$4=4T1F4x4*2V51390*0z0r4E1B4%1-4I5d2;4d5g0#424L4|564c4r5j01535r4q595b0z5r5f504h4.4R5B4-1F5l4`103E0z2p2Q5M3n1j3p2s2u2q1Q1S2s0k1A5P0I3o0,5$0P0R0T04.

###(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

.12801354tf)2r3sao iugxm1Ppnlh.e=cy:v(wS/b_dk050L0z0d0k0n0w0j0m0B0w0k0j0j0A010d0n0u010406050j0o0r0r0k0h0C040H0l0w0o0%0l0v050I0.0:0=0@0,0u041017051a0I1a1c170,0L0n0E0V0X0Z0#0x0n0p0x0w1q0x0d0*050Q0J0w0z1l0Y0!011p1r1t1r0d1z1B1x0d0J0l0L0@1y0h180d0x0V0`0j0u0k0v0#0g011D1n010e0S0z0v0k0r0z1x1#1%1,1F1/1B1=1@0*0a0m0t0h0l0u0l0j0n0}0v0m0O1Z0h0h0z0B2c101`0v180I1X2p0d1V1U1W0L1|0#1t0v1;291x1i1k0W1E2z0n2B0v1R1j1x0u2i182n2p2T0-1$2d2H1-2M0h0;0w0*0s2m2X0+2W1{2Z1F2#2%0*0g2+1%2-2n2y012=0k2(040i2_2o0,2|2:0#2 310c342{2X2}3a0*0b3d192R102F2s0L2w2}0B1R1^183o1b3m2V112,053t0O2S3f38010M0*0O0e3k371m1F0G0*0m3O3H3Q390e0*2i0v0E0z0h0j0z0K0O0o0q3V2/3X010)040F3:2Y3=0v0*0u3`2}3@0f0D3d060m473U3P2I2~0*0k3d493W4b0l0*0A4f2.3{4b3}043 3B2`4n2}4j040y403I4q0O0u1:4A3=3@0F0f45484g3;4p0*0J4m4a1-4x4l4t2o4N4o2!3~4G4i0*4z4X3G4O4#044D4F4+4v3I4I4K4+46484?3|4$4=4T1F4x4*2V51390*0z0r4E1B4%1-4I5d2;4d5g0#424L4|564c4r5j01535r4q595b0z5r5f504h4.4R5B4-1F5l4`103E0z2p2Q5M3n1j3p2s2u2q1Q1S2s0k1A5P0I3o0,5$0P0R0T04.
Renverser les k valeurs au sommet

Écrire la fonction renverse_k qui prend en paramètre une pile ainsi qu'un entier k et renverse l'ordre des k premiers éléments de la pile. Les autres éléments ne sont pas modifiés.

La transformation se fait en place : on modifie directement sur la pile et il est donc inutile de la renvoyer.

On garantit que la pile compte au moins k éléments.

>>> p = Pile()
>>> p.empile("a")
>>> p.empile("b")
>>> p.empile("c")
>>> p.empile("d")
>>> p.empile("e")
>>> p
| a | b | c | d | e | <- sommet
>>> renverse_k(p, 4)
>>> p
| a | e | d | c | b | <- sommet
Aide

On pourra utiliser deux piles annexes.

Etape 1

Etape 2

Etape 3

Etape 4

###(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

.1280135tf4)2r3,sao iugx8m1P6pnl7h.e=cy:v9(wS/b_dk050Q0D0c0l0o0z0k0n0F0z0l0k0k0E010c0o0x010406050k0p0t0t0l0h0G040M0m0z0p0,0m0y050N0?0^0`0|0;0x04151c051f0N1f1h1c0;0Q0o0I0!0$0(0*0B0o0q0B0z1v0B0c0/050V0O0z0D1q0%0)011u1w1y1w0c1E1G1C0c0O0m0Q0|1D0h1d0c0B0!0 0k0x0l0y0*0g011I1s010d0X0D0y0l0t0D1C1*1,1;1K1@1G1`1|0/0a0n0v0h0m0x0m0k0o120y0n0T1(0h0h0D0F2h151 0y1d0N1$2u0c1!1Z1#0Q210*1y0y1_2e1C1n1p0#1J2E0o2G0y1W1o1C0x2n1d2s2u2Y0=1+2i2M1=2R0h0_0z0/0u2r2$0:2#202(1K2*2,0/0g2:1,2=2s2D012`0l2-040i2~2t0;312^0*34360e39302$323f0/0b3i3b3k3d330m2+350/0w3p2?2%1r2_3u2{040A3z3c3C3e3E3w040s3I3r3K3t3v360J3i1e2W152K2x0Q2B320F1W1}1d3#1g3Z2!162;053*0T2X3R2N010R0/0T0d3X3J3|0L0/0n423{2)0d0/2n0y0I0D0h0k0D0P0R482@3S0.040K4m3B3|0y0/0x4s324p0j3i47432)0/4l3=2 3A4z0/0f0H3p0n4Q4D492_0/1,2G0r4j2/4I2t4S4n3|0m0/0E4C4K3s4v040v1^4y3s4p0K0f4P4R4.3S4:4W0D4Y0P2}4#044%4t1=4*044,56583l0/4=1G4@4o0/4`4|4Q4~3|3~040d3u4-4E4U040P5w4T0*0m45042P5B4(2)0O4c1,0q0D5k3|4_5Q4F044H2!5x0*4p4N5o4R5p5Y334V0y4X4Z5T1K5b0C5/3e0/0D0t0x4?565q1=5S5}5)4:4x615C015;5?5*040T5{5j655J1K4_0f4{56065%5~1K5s5u0h5I595y5A5e6o5D5F5H6x625L040h5N5P6f6u5Z5m694:5W3?5)5!4O6l5%6n625+5-5469686J5g045_6d6I5X66606-6g5@0451534!6:6K670/5=6%4/3 0D6+696i6k2Y6m4}5)6q5v6C664:6w2Y5f3s5E0/6B7h6y336E6G0y5O746M6 4 4G7u045#6U6V5(7e4w6#6}6N5^5`5|6`4L4q7J6?5,524j557N7j7I7w4u71737Z5 5m6j3z0N3^0D2u2V7.3!1o3$2x2z2v1V1X2x0l1F7;0N3#0;810U0W0Y04.

###(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

.1280135tf4)2r3,sao iugx8m1P6pnl7h.e=cy:v9(wS/b_dk050Q0D0c0l0o0z0k0n0F0z0l0k0k0E010c0o0x010406050k0p0t0t0l0h0G040M0m0z0p0,0m0y050N0?0^0`0|0;0x04151c051f0N1f1h1c0;0Q0o0I0!0$0(0*0B0o0q0B0z1v0B0c0/050V0O0z0D1q0%0)011u1w1y1w0c1E1G1C0c0O0m0Q0|1D0h1d0c0B0!0 0k0x0l0y0*0g011I1s010d0X0D0y0l0t0D1C1*1,1;1K1@1G1`1|0/0a0n0v0h0m0x0m0k0o120y0n0T1(0h0h0D0F2h151 0y1d0N1$2u0c1!1Z1#0Q210*1y0y1_2e1C1n1p0#1J2E0o2G0y1W1o1C0x2n1d2s2u2Y0=1+2i2M1=2R0h0_0z0/0u2r2$0:2#202(1K2*2,0/0g2:1,2=2s2D012`0l2-040i2~2t0;312^0*34360e39302$323f0/0b3i3b3k3d330m2+350/0w3p2?2%1r2_3u2{040A3z3c3C3e3E3w040s3I3r3K3t3v360J3i1e2W152K2x0Q2B320F1W1}1d3#1g3Z2!162;053*0T2X3R2N010R0/0T0d3X3J3|0L0/0n423{2)0d0/2n0y0I0D0h0k0D0P0R482@3S0.040K4m3B3|0y0/0x4s324p0j3i47432)0/4l3=2 3A4z0/0f0H3p0n4Q4D492_0/1,2G0r4j2/4I2t4S4n3|0m0/0E4C4K3s4v040v1^4y3s4p0K0f4P4R4.3S4:4W0D4Y0P2}4#044%4t1=4*044,56583l0/4=1G4@4o0/4`4|4Q4~3|3~040d3u4-4E4U040P5w4T0*0m45042P5B4(2)0O4c1,0q0D5k3|4_5Q4F044H2!5x0*4p4N5o4R5p5Y334V0y4X4Z5T1K5b0C5/3e0/0D0t0x4?565q1=5S5}5)4:4x615C015;5?5*040T5{5j655J1K4_0f4{56065%5~1K5s5u0h5I595y5A5e6o5D5F5H6x625L040h5N5P6f6u5Z5m694:5W3?5)5!4O6l5%6n625+5-5469686J5g045_6d6I5X66606-6g5@0451534!6:6K670/5=6%4/3 0D6+696i6k2Y6m4}5)6q5v6C664:6w2Y5f3s5E0/6B7h6y336E6G0y5O746M6 4 4G7u045#6U6V5(7e4w6#6}6N5^5`5|6`4L4q7J6?5,524j557N7j7I7w4u71737Z5 5m6j3z0N3^0D2u2V7.3!1o3$2x2z2v1V1X2x0l1F7;0N3#0;810U0W0Y04.
Fusionner deux piles de mêmes tailles

On considère p et q deux piles contenant le même nombre d'éléments.

On appelle « fusion de p et q » la pile obtenue en empilant alternativement les valeurs dépilées de p puis q.

Écrire la fonction fusion_simple qui prend en paramètre deux piles de même taille et renvoie la pile résultante.

Les piles p et q peuvent être modifiées lors du traitement.

>>> p = Pile()
>>> p.empile("c")
>>> p.empile("a")
>>> p
| c | a | <- sommet
>>> q = Pile()
>>> q.empile("d")
>>> q.empile("b")
| d | b | <- sommet
>>> fusion_simple(p, q)
| a | b | c | d | <- sommet

###(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

.1280135tf4)2r3,sao iugm1P6pnlh.e=cy:v(wqS/b_dk050N0A0c0l0o0x0k0n0C0x0l0k0k0B010c0o0v010406050k0p0r0r0l0h0D040J0m0x0p0)0m0w050K0:0=0@0_0.0v041219051c0K1c1e190.0N0o0F0X0Z0#0%0y0o0q0y0x1s0y0c0,050S0L0x0A1n0!0$011r1t1v1t0c1B1D1z0c0L0m0N0_1A0h1a0c0y0X0|0k0v0l0w0%0g011F1p010d0U0A0w0l0r0A1z1%1)1.1H1;1D1@1_0,0a0n0t0h0m0v0m0k0o0 0w0n0Q1#0h0h0A0C2e121|0w1a0K1Z2r0c1X1W1Y0N1~0%1v0w1?2b1z1k1m0Y1G2B0o2D0w1T1l1z0v2k1a2p2r2V0/1(2f2J1/2O0h0?0x0,0s2o2Z0-2Y1}2#1H2%2)0,0g2-1)2/2p2A012@0l2*040i2{2q0.2~2=0%31330e362}2Z2 3c0,0b3f383h3a300m2(320,0u3f1b2T122H2u0N2y2 0C1T1`1a3A1d3y2X132.053F0Q2U3o1o1H0O0,0Q0d3w393U0%0H0,0n3!3T2K300d0,0d0p2c100M2c0r0v1D3+2;3$010+040G3}2!3 0w0,0v442 410j3f3*3#3-47040I4a3p410f0E3m0n4r4f3,2$0,0h4e2:453-0m0,0B4y4g4v040t1=4l3 410G0f4q4s4z2 3W040H1r3|3N2|4t3~4B3(042O0c4F4u2?484L4B0,0z4:4H0A0k0c0M0F0o0Q4@1H4N4o4Q4s4R4G4.044x4Z2q4S3p4C044?5b3S4$4^3`4K5i5d4M0,435o573b4/5t4-0%5f5h2X5u303X0A0v5n5C5y405r0f4P5i0655555p4h4w505z4=5W5E040A5m4Y5J5k515r5Z4i4k5x5*5X5g5-5F5H5(3O5D525O2V5Q565K4U2k0c0p0h115i4#4A4H5a5 123Q0A2r2S6h3z1l3B2u2w2s1S1U2u0l1C6k0K3A0.6x0R0T0V04.

###(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

.1280135tf4)2r3,sao iugm1P6pnlh.e=cy:v(wqS/b_dk050N0A0c0l0o0x0k0n0C0x0l0k0k0B010c0o0v010406050k0p0r0r0l0h0D040J0m0x0p0)0m0w050K0:0=0@0_0.0v041219051c0K1c1e190.0N0o0F0X0Z0#0%0y0o0q0y0x1s0y0c0,050S0L0x0A1n0!0$011r1t1v1t0c1B1D1z0c0L0m0N0_1A0h1a0c0y0X0|0k0v0l0w0%0g011F1p010d0U0A0w0l0r0A1z1%1)1.1H1;1D1@1_0,0a0n0t0h0m0v0m0k0o0 0w0n0Q1#0h0h0A0C2e121|0w1a0K1Z2r0c1X1W1Y0N1~0%1v0w1?2b1z1k1m0Y1G2B0o2D0w1T1l1z0v2k1a2p2r2V0/1(2f2J1/2O0h0?0x0,0s2o2Z0-2Y1}2#1H2%2)0,0g2-1)2/2p2A012@0l2*040i2{2q0.2~2=0%31330e362}2Z2 3c0,0b3f383h3a300m2(320,0u3f1b2T122H2u0N2y2 0C1T1`1a3A1d3y2X132.053F0Q2U3o1o1H0O0,0Q0d3w393U0%0H0,0n3!3T2K300d0,0d0p2c100M2c0r0v1D3+2;3$010+040G3}2!3 0w0,0v442 410j3f3*3#3-47040I4a3p410f0E3m0n4r4f3,2$0,0h4e2:453-0m0,0B4y4g4v040t1=4l3 410G0f4q4s4z2 3W040H1r3|3N2|4t3~4B3(042O0c4F4u2?484L4B0,0z4:4H0A0k0c0M0F0o0Q4@1H4N4o4Q4s4R4G4.044x4Z2q4S3p4C044?5b3S4$4^3`4K5i5d4M0,435o573b4/5t4-0%5f5h2X5u303X0A0v5n5C5y405r0f4P5i0655555p4h4w505z4=5W5E040A5m4Y5J5k515r5Z4i4k5x5*5X5g5-5F5H5(3O5D525O2V5Q565K4U2k0c0p0h115i4#4A4H5a5 123Q0A2r2S6h3z1l3B2u2w2s1S1U2u0l1C6k0K3A0.6x0R0T0V04.
Fusionner deux piles de tailles inconnues

On considère p et q deux piles dont on ignore le nombre d'éléments.

On appelle « fusion de p et q » la pile obtenue en empilant alternativement les valeurs dépilées de p puis q.

Les piles n'ayant pas nécessairement le même nombre d'éléments, il est possible lors de la fusion que l'une d'elles soit vide avant l'autre. Dans ce cas, on terminera la fusion en vidant l'autre pile dans la pile résultante.

Écrire la fonction fusion qui prend en paramètre deux piles de tailles inconnues et renvoie la pile résultante.

Les piles p et q peuvent être modifiées lors du traitement.

>>> p = Pile()
>>> p.empile("e")
>>> p.empile("c")
>>> p.empile("a")
>>> p
| e | c | a | <- sommet
>>> q = Pile()
>>> q.empile("d")
>>> q.empile("b")
| d | b | <- sommet
>>> fusion_simple(p, q)
| a | b | c | d | e | <- sommet
Aide

On pourra organiser le code en trois temps :

  • les deux piles sont non-vides ;
  • la pile p est non-vide ;
  • la pile q est non-vide.

###(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

.1280135tf4)2r3,sao iug08m1P6pnl7h.e=cy:v9(wqS/b_dk050R0D0c0l0o0z0k0n0F0z0l0k0k0E010c0o0x010406050k0p0t0t0l0h0G040N0m0z0p0-0m0y050O0@0_0{0}0=0x04161d051g0O1g1i1d0=0R0o0I0#0%0)0+0B0o0q0B0z1w0B0c0:050W0P0z0D1r0(0*011v1x1z1x0c1F1H1D0c0P0m0R0}1E0h1e0c0B0#100k0x0l0y0+0g011J1t010d0Y0D0y0l0t0D1D1+1-1=1L1^1H1{1}0:0a0n0v0h0m0x0m0k0o130y0n0U1)0h0h0D0F2i16200y1e0O1%2v0c1#1!1$0R220+1z0y1`2f1D1o1q0$1K2F0o2H0y1X1p1D0x2o1e2t2v2Z0?1,2j2N1?2S0h0`0z0:0n0u2s2%0;2$212)1L2+2-2/0g2=1-2@2t2E012|0l2.040n0i302u0=332`0+36380n0e3c322%343i2/0b3m3e3o3g350m2,372/0w3t2^2(1s2{3y2}390A3D3f3G3h3I3A390s3M3v3O3x3z3j0J3U2_3W3q040u0r3m1f2X162L2y0R2C340F1X1~1e3:1h3.2#172?053^0U2Y3V2O010S0:0U0d3,3N470L2/4d462*0d0:0d0p2g144i3$470/040K4r3F470y0:0x4x344u0j3m0n3E3p0:0M4D3w4u0f0H3t0n4T4I4e2*0:0h4H4J3w0m0:0E4!4W2{0:0v1_4N3W4u0K0f4S4U4#3W49040L1v1H4*4j1L0m4g042S0c514s4X044C40314`474%040C4:4z0:0D0k0c0Q0I0o0U5l1?4=4@5e2u4V520+540:1-0R594y1?5E560m585z395g5b4M5P5R530:5k5U4+3h5n5p5r5t0D5v1L5x4R5P064U5;5B5a4,044Z5Z5C015i5Y2#5!355n0t0x4/5{5@0+4=5+5#5c6b5}5X6e4A040U6550675J5,0:4?5y2Z5:5=4T5V6c5`605|5~6h636l5*6n4E6q6D045T6A686f5j6K6k666N6o696q0f6s2?6u6w614|4~6T2?5?6V5}55575I4K6d6H4$6g6@3%5$5q5s5u6`4t6X5.6t6v6$5|6i6z41616C705b0D646*5f616a7d5^5d6U347c7o3w6i6S6m7r4;6X6Z316#6,346(4 6G2Z7C4$6/5N6;7s4L6e7q7a776|5(6 7w714v4Q4^6v6x625_7P6_7W7e7g7v7R6O7k7+5^6M7/6-7Q7i7S6j0D6F6e5x7z3d5;7$4|2o0c0p0h155P7I6{7(5/16430D2v2W8j3/1p3;2y2A2w1W1Y2y0l1G8m0O3:0=8z0V0X0Z04.

###(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

.1280135tf4)2r3,sao iug08m1P6pnl7h.e=cy:v9(wqS/b_dk050R0D0c0l0o0z0k0n0F0z0l0k0k0E010c0o0x010406050k0p0t0t0l0h0G040N0m0z0p0-0m0y050O0@0_0{0}0=0x04161d051g0O1g1i1d0=0R0o0I0#0%0)0+0B0o0q0B0z1w0B0c0:050W0P0z0D1r0(0*011v1x1z1x0c1F1H1D0c0P0m0R0}1E0h1e0c0B0#100k0x0l0y0+0g011J1t010d0Y0D0y0l0t0D1D1+1-1=1L1^1H1{1}0:0a0n0v0h0m0x0m0k0o130y0n0U1)0h0h0D0F2i16200y1e0O1%2v0c1#1!1$0R220+1z0y1`2f1D1o1q0$1K2F0o2H0y1X1p1D0x2o1e2t2v2Z0?1,2j2N1?2S0h0`0z0:0n0u2s2%0;2$212)1L2+2-2/0g2=1-2@2t2E012|0l2.040n0i302u0=332`0+36380n0e3c322%343i2/0b3m3e3o3g350m2,372/0w3t2^2(1s2{3y2}390A3D3f3G3h3I3A390s3M3v3O3x3z3j0J3U2_3W3q040u0r3m1f2X162L2y0R2C340F1X1~1e3:1h3.2#172?053^0U2Y3V2O010S0:0U0d3,3N470L2/4d462*0d0:0d0p2g144i3$470/040K4r3F470y0:0x4x344u0j3m0n3E3p0:0M4D3w4u0f0H3t0n4T4I4e2*0:0h4H4J3w0m0:0E4!4W2{0:0v1_4N3W4u0K0f4S4U4#3W49040L1v1H4*4j1L0m4g042S0c514s4X044C40314`474%040C4:4z0:0D0k0c0Q0I0o0U5l1?4=4@5e2u4V520+540:1-0R594y1?5E560m585z395g5b4M5P5R530:5k5U4+3h5n5p5r5t0D5v1L5x4R5P064U5;5B5a4,044Z5Z5C015i5Y2#5!355n0t0x4/5{5@0+4=5+5#5c6b5}5X6e4A040U6550675J5,0:4?5y2Z5:5=4T5V6c5`605|5~6h636l5*6n4E6q6D045T6A686f5j6K6k666N6o696q0f6s2?6u6w614|4~6T2?5?6V5}55575I4K6d6H4$6g6@3%5$5q5s5u6`4t6X5.6t6v6$5|6i6z41616C705b0D646*5f616a7d5^5d6U347c7o3w6i6S6m7r4;6X6Z316#6,346(4 6G2Z7C4$6/5N6;7s4L6e7q7a776|5(6 7w714v4Q4^6v6x625_7P6_7W7e7g7v7R6O7k7+5^6M7/6-7Q7i7S6j0D6F6e5x7z3d5;7$4|2o0c0p0h155P7I6{7(5/16430D2v2W8j3/1p3;2y2A2w1W1Y2y0l1G8m0O3:0=8z0V0X0Z04.