Anagrammes⚓︎

Deux chaines de caractères de même longueur sont des anagrammes s'il est possible d'écrire l'une en utilisant tous les caractères de l'autre, quitte à les déplacer.

Par exemple les chaines chien et niche sont des anagrammes, alors que louve et poule ne le sont pas.

Déterminer si deux chaines de caractères sont des anagrammes peut se faire en les comparant après les avoir triées.

On utilise ici une autre approche, récursive :

  • si les deux chaines sont de longueur 1, on renvoie True ou False selon qu'elles sont égales ou non
  • sinon, on teste si le premier caractère de la première se trouve aussi dans la seconde :
    • si oui, on recommence le test sur les deux chaines dans lesquelles on a retiré la première apparition du caractère testé
    • si non, on renvoie False
Exemple

Pour tester si chien et niche sont des anagrammes :

  • on observe que c est bien dans niche
  • on teste si hien et nihe sont des anagrammes
  • on observe que h est bien dans nihe
  • on teste si ien et nie sont des anagrammes
  • etc
  • on observe que n et n sont égales : on renvoie True

Vous devez écrire deux fonctions :

  • supprime_premier(chaine, cible) renvoie un couple (present, chaine_sans_cible) dans lequel :
    • present est un booléen indiquant si le caractère cible est présent dans chaine,
    • chaine_sans_cible la même chaine si cible n'est pas présent, la chaine privée de la première occurrence de cible si elle est présente
  • anagramme(chaine1, chaine2) renvoie True si les deux chaines sont des anagrammes, False sinon

On garantit que les deux chaines sont non vides.

Exemples
>>> supprime_premier('ukulélé', 'u')
(True, 'kulélé')
>>> supprime_premier('ukulélé', 'é')
(True, 'ukullé')
>>> supprime_premier('ukulélé', 'a')
(False, 'ukulélé')
>>> anagrammes('chien', 'niche')
True
>>> anagrammes('énergie noire', 'reine ignorée')
True
>>> anagrammes('louve', 'poule')
False
###(Dés-)Active le code après la ligne # Tests (insensible à la casse)
(Ctrl+I)
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
.128013lS]et-d5f18umaèg,_F/R=in 6)yàqPhcL[(bsx.p;r4j'90"ovT+w73Ok:é 2030b08090i0r050G0%0B050i0G0G0q0R090r0J0R020t030G0g0h0h0i0L0w02060S050g0{0S0s0%000i0h0J0K0%0p08150L0y0g080G030o12141618100J02031D1w1G0o1D100b0r0T0:0=0@0_0A0r0k0A051U0A090~030+0F05081P0?0^0R1T1V1X1V091%1(1#090L1E090A0:1b0G0J0i0s0_0'0R1*1R0R0d0-080s1j081#2022271,2a1(2d0h2f02040%0z0L0S0J0S0G0r1e1g0)1~0L0L080B2A1w2h0s1E0o1|2M1_1{1`1$0b2j0_1X0s2c2x1#1M1O0;1+2W0r2Y0s0S2$1#0J2F1E2K2M2?11211g2'282,0L15050~0%0e2J2`0 2_2i2|1,2~30320'3522372K2V0R3c0i31020%0Y3g2L103j3a0_3m3o0%0M3s3i2`3k3y320c3C3u3E3w3l0S2 3n320u3J382{1Q3b3O3d3p0X3T3v3W3x3Y3Q3p0f3$3L3'3N3P3z0P3-393/3G020e0Q3@3V2(3:3Z0e341x363K3^403`0e3f453h473 2}3)3o0e3r4d3t3U3F4i0~0e3B4m3D484h3;4r3I4u4f4p4y3{3S4B4o3M4a3#4H3%494q3{3,4M3.4O4E0e3?4S4w3X4E0'3}4Y4g4!3Z0'442?4C4J4P0'4c2^1J2;1w2$2P0b1{2U3M0B2-2p0(1N1E2:082=363C03500)584Z0_0!0~0)0d3C0%4I3_0d0~120J2:0r2o0m560h0r080L5a4N280}020E5C4T2}0~0B0A0,2Y5I5f0R5F0#5l5n490F5q1_5Q4(0_5F0l5V5D3b5L0r1'085#3k5T5)5J3b5Y020G5!4u5W5E0~0v5?5R0S0~0a000k090K625$3l5_5{5B5}5*5%0~5U4B0%6n5m6i3l0~2F12050+096b3k64020q6y3M0G2502001s0S696I0g6K6a6m6o5~5+020)0N0i0m0T0g6D3/6A6C4u6p5@5g0B0~0n3n0G5/6Q6n6S5g0~0d3O6#495L160i2H5A6;2?6)630W0~2*6|5K025M5O73596q5=6=6o6?6q5h020r5k6(6@6r7c6 712F7a1,6%6'747s0s5,5.7y0_0S7702220b7H0R7J0~2,6x7r6q7E6U086W6Y6!6h6*5S6k3J7k7*6R7V5i7Y6X6Z7O6%7O0!6,020U0L1t7)7+756c7n080.7f3h7s7i4-7 7*7D6s1u0g6v0i7T7C6q6A0V7B36803F6~0L7009727~7l7%7n2F090g0L0s7O7W6V7:7#2^7h0~5(7U7%7W6t8f6w3J0t4.3/7n5j8F5p7L2d0k8s141u5:3M5F5H7$5R7W7d2*084,7g7%888o7D6e5|8K8`8M8F5L5N8?4=8_5R8{3h8p4J8~6g9099607=6567698F5_0F0S1b8+3/9a3t7k7s7n7p9n0~2m9s408-9D7b8=2Y8^868L02618O630~0q8n9b7s5y4r9G1,9u0 8a9x8d8B8D937c959J9j6B9T2L9c3_947e974e9w7m0~836:9Y6j026l897 8c7c5-1(9.9:3pa69I8@a07'020Dag9W024%9g6c5F078w8b7-020T8s0rag5'9*ae0e0m0G220G0m0Ba8859;7s7?9P6c7W5r5t5v5x5z9f98ap0~8.ao8q9+7e9K2L8792aPa%aJ7G8/aZ9Nas9{8P7F1(0m0baG0m9_a*9M8N8ja_a'96aEa~a/a9a-3MaOb48:5q0g5s0L5u085w2F5y5Aaza!ag8;9,08b05ea=b38|aubaaLby5;9i7ja^5R9y7qbfaQa`bma}0saHbxa+a2a@a59|028A8C8Ebc9?8$0i8'1j2o1va;bG5Gbt9@8?aDaFbSaIaKbr02bA9UbCbv0'b8b`bDb}9Oa47+9%029~bEbVa3468abJ819'b$7@7_6.843T0o5c571H4^0o4`1w094|cz2S2N0i5.2M4`1CbF3Mbo0m0d0i0!bm0A0Y0~1o1q1s1u0%cg861J371D0C0i0%6`0s2H0r1f5mct5`biaTbmaVbqcs513p0s0$0B1u2y8u0%2C1M5{2*0k1t0L0%0J1c2y088C0/0B0?d41)2ad92FcZ1H378f371X021(0:7v090jdp1c0%1u09d47p0d0$2F0sdG0b0gdy8s2HdB1)5M5A5M0$cZ0%c/dx2F500J5z1wdv10dvdxdjdRdAdCdPdF0%0$0k3n0%0idPd/8tdT0:0AdW0AdY0*0%0-0%0s0Oc)210/2c50dp0$09dY1_0S0g0TdY5Hc;566:dM1wc;0%09en0Nen0L0/0xc:513k1.1W1Y1!cK8Xco6/cec{5d0vdZc/2Y0%d$2G2v5zdc0?0l0%150r0/c/2*1McX0%1s0Od#ecey2ueoe6dGaSbk0heq5beH3MeJ1:1Z2gb5et2c8ibB7%befdbK7_7{7}5}eS579Od+03d-dUdze1dDd@d_d{d}dQe0dpdV0LdXdEdGe9c)0b0$0NeFejele`ep1xc?e dY0#d!1geZd'd)0ofpdvc/dL0T0Se$2w8Cc*2*0rdbd.endd1)f25d0EfadMe(8R8g099Oc;d*0r370odtcJ0zeCeYc)c+c-c/f`5722b*8(b-ewc|dqc$10g9fqg62yeYcY0)0g0He27e0/0G1fdN1)051fd9dgdb0ee(f(2cf*e$d$0$6u6wdlgxf.501k6 e+c/0Edj0/2C0F0?1)2C0=0%0Lc dh1N2z0$fog6d,gv2*1fgP1ge~blgxdcboaWfAdSdp2Cgib69-fm3pbR0/1(g+dggBaeb.f%g67d0B0g2BcY0i5s9~eG5dh4aUh85Ag)bve(bDg3gpf)f+gIc)aeg=0$dO2z08e(e*0/d}0@0r0%hv0%9p1b0$2ce80se/0g22e}h$g;hec6hhd^0+2zh7gVfbg/aGgdgC8?g5dug6c/6:dl15h.1)3n3OgEh$h^b|h`ej0,dNi2h^c2go5d0%0Edxc_dbd hbg/f_c;aCis57dE5{eac d10,bofbd4ipiDbv44c;0v0I0%0Z1g8u5{080t0b1f0Bh6h)05h+1ghN0wdY21dbhehDc^hF0LhH9^hJaKhLit5Ugtdvgw0B0Od@d.e'fXd|hz05dxg;gf2A0%12iycYhp0%0Rg?hUi!0Ri6g~5`h$d0eaj7iIeeh6g*h2g=gRhOhBdU3/f5eLf8fh6-eQ5ah`1Md%8u2oevf$g}1wgtjZg7j$0)h|0.02.