important
liste/tableau
tuple
Démineur
On souhaite générer des grilles du jeu de démineur à partir de la position des bombes à
placer.
On se limite à la génération de grilles carrées de taille \(n \times n\) où \(n\) est le nombre de bombes du jeu.
Dans le jeu du démineur, chaque case de la grille contient soit une bombe, soit une valeur
qui correspond aux nombres de bombes situées dans le voisinage direct de la case (au-
dessus, en dessous, à droite, à gauche ou en diagonale : chaque case a donc 8 voisins si
elle n'est pas située au bord de la grille).
Exemple
Voici un exemple de grille \(5 \times 5\) de démineur dans laquelle la bombe est représentée par une étoile :
On utilise une liste de listes pour représenter la grille et on choisit de coder une bombe par la valeur -1.
L'exemple ci-dessus sera donc codé par la liste :
Python [[ 1 , 1 , 1 , 0 , 0 ],
[ 1 , - 1 , 1 , 1 , 1 ],
[ 2 , 2 , 3 , 2 , - 1 ],
[ 1 , - 1 , 2 , - 1 , 3 ],
[ 1 , 1 , 2 , 2 , - 1 ]]
Compléter le code ci-dessous
La fonction genere_grille permet de générer des grilles de démineur.
On pourra vérifier que l’instruction genere_grille([(1, 1), (2, 4), (3, 1), (3, 3), (4, 4)]) produit bien la liste donnée en exemple.
.128013]ik[v8o-)yqxb.I+g=mç4rsù97f,d :5hwtcl0p_!P3(a;jR/àeèS612énu050D0Z0J0T0c0L0x0E0K0L0T0x0x0s010J0c0N010406050x0+0t0t0T0w0k040#0h0L0+0 0h0*050X16181a1c140N04051s1l1v0X1s140D0c0f0@0_0{0}0_0*0r0+0T0r0Z0i0N0k0J0H1j0E0H0c0r0H0L1X0H0J12050/0n0L0Z1E0`0|011W1Y1!1Y0J1*1,1(0J0w1t1S0@1f0x0N0T0*0}0(011.1G010B0;0Z0*0T0t0Z1(23252a1:2d1,2g2i120a0E0Q0w0h0N0h0x0c1i0*0E0-210w0w0Z0K2D1l2l0*1t0X1S2Q1}1 1~1)0D2n1H0c0*2f2A1(1B1D0^1/2!2$0*0h2*1(0N2J1t2O2Q2`15242E2,2b2:0w190L1(0T1V2J0B0}030O0O0K2;0Z1!2/0h0i0%3l120E0%1l0T2{2~132}2m301:323436380Z3a013c3e3g3i2%3l0i28040E0(3r3t253v2O2Z013A0T351t370H393b3d3f0-3K2:3M0R3o0R3S2N3u143W3y0}3Z3#053%3)3G3+3J2#3L3m0v3o0v3@1m3_3w2 1F3z0h333!3C3(3E3*3I3-463/3m0G3o0G4c2`3`2~3X3~4m423H3,3h4s3k3m0$3o0$4y4e3{4h3}4j3B3$3D3F4G453j3M0A3o0A4P3U4A3x4S3Y4U4l4W4n4Y444r4#3m0g3o0g4*2P4,4g2-4/4k3 414o434q4I4`0i0z3o0z4 3V4B3|544V404X4p4H3.4K3l0M120%0M5h514C4:565o595q4J3M0%0%5v3q0X3s3^4+4f5A554E584Z4_473l3O0%3R5M3T505Q5k4D4=4F4^5b5X0%3;045;5y5)4.5+5n4?5p4!5:495?4b5$5O5(4R535{574@5a5r5H4v5?4x644d5P67315B5T6b5F5c0%4M5?4O6i4z5_686n5,5U5.6d3m0%4%5?4)6w4Q5j5`6A5|5-6c5G6F4|5?4~6K6k6M6z5S6B6p5 4t3l5e5?5g6X666Z6m6#6P6C6R5c0(5u046`5^6l4i6=6a5~5W6)0(5J6|5L5N6j6/4-6!5m725E6(5s0(3O7k6~6:707f5D5V5/755=0(3?6.5i7d6;7q5}7h747j610(637a6x6 4T717r6D6S3N6f0(6h7K6L7A7p4;6?6%7F3M0(6t7)7n7Y7N7C6Q6q5X0(6H7?7,527B7!7g7s6E3N6U0(6W7W6Y7-5l7|7P6^7=6+0(6-847c7`7Z5C7D7~7R0R6{8n7_5R7/6@7;6)0R778w8q5*6O7}7Q5c0R3O8F5h1w2^1l2*2T0D1 2Y5k4H2)1C1t2@0Z2_3u651t4H8Y2m0c0D0}3d2O5H3C8)8+8a6)5J0E2r0Z8;8u5s773@7M010d120-0B8!6y2b0I3o96900*0B120f0h0c2B2g1N9b7o0}11040S9m860*121k7b8%8h9o120C8!0E973z121@2$9s9z019p9C9x9E9c123f0L1j9J9x9F9A040j0F8!149X3W8:018,2~7(8/8*9,8=7j298_8{7i9/2Q5N90993P0Ea29K3X0x0D12020l0+0h0J0Ua9abadafac0U0E0W2f9g0c1-0_0E1!0x0J1-0-0?3f4j0D9V0)0Z0?ax0Eao9jaFaq370K0`0Z9%a49+9-253:9:9`7%3m3;8^2h8`9=8|aV9}9ya5a7a1a2a:0E0S9I0Z0C219U0*2$0j0E2f0E0r0!0w250JasaE0@aO0?160wb70?0naA0x0o0Eaiahaaajbl0UaQ9)4BaS0O8-48aWa(9{bxa#2iaX7t5s613Sa;9Y3Y9f9haJ9DbK0h120sbP909p0e0bbr2|9*9;aT0*3M6f5nbua)4u9^a$bE7 b*5$bJ9092040B4jbU9nbL040Lb~860ha02#c39L0*0n12b41JaPbs869p9rcgc9cb04190ma45kcicq4.0t0c125xck3X9Nc84C9H1X9W2`9Qb bR040icC5kcv5vct539p0j9OcHbKca12cv9wb!b cscz5*9vcR2bcB9PcXcE0rcG3ucIc4120qcNcucw6|c,1:cT9#bZ8Zb#8;bw0i6tb+b$9?3M4MbCa%8D5Xdab@a;a:bKb`b|0wc|689Sds2bc512c7c/9ccmcd9lc)4.c(c$9tcmcod09ZcjdI9LcP04cydPcA9Bdv9G049T9VcfcW90cKcMdAb dR5LdUcr12cUdX3}dKdzd/dG12dOd5b 9u04c#d~chdWd+9t9S1fd#d?01cKc{e6dQc~5#d`cSd;d39x9(dUbud86Hdbb;7R4%dgeu5cesdldmdmdody95efdV9qdMc0c2dFek04cVc@c:dZeKcTebcK0PbTeHd:eJeN31c;c?3UbKc.d%d e8a{e*2Pe,d;9$enaRdcd86UetbzaY0i4|exf0bF3Me~eBeCfaeSaI2#0xeKcK0oeKe00T0N0N2f0DeUd|d}e+9Rc1fqePebe00Kfw0j0jd4ftbte|9.3m6+e di6)5ef4fM5sfKf9eE042J0J0+0we23Uc^c9bM9ifefEe?d69=d85wbyfQ5H5ufPdd6F6{3Seoe32EeqfI3l8~37b,bAg2b/bDf57 5I1(64b_933EeKa09Ee%3z9e042#0K2J2i0*av0Ofd0*ffgldNfj120r0w0;1,fweQf#eSa@gHfye:eagz9Me^f+a,g0aU6F3OfLf_5Yg8dhg!5!gd9~b gjdngQa6a8bnbmagaeg=ak0p0*gq0)gsav2F1-0%0E0J0h1hb81,aybaaHbN46aF02030R0z0U0+2$0Ebg0t0n0Zbjbphtg_gT5QgVb(6F5=gZb-3la!9_ga7R5;g*a/f$cD04gwgye.c_04eZhRf%hOhd9kd$f~eIfsf,d cm2qfwh%a,c*04gDgFh!fFe49!gI2PhMh/gLgQe-eRfud!a|h?h(h^fDe`czhy5HbHg4dchD0%49f^igbHfTgfb{b}e!5`9HgMiqdteTiudwc6f!h{fchYhQh#e#e_6xiafHgW3lb*ieey5:4vijg60%b?3sfah|4.b`0ceGhVhNh;0LgGh 120egBfvi,040bi.gQfzfwbYix1:eXhUi1cJ12d*ej2bd-fwiHj0860K77030E2B0@1-0*hghi0UaEb6240?hl1-hohqhwf-b%5HdaiOhH6rdfhGf=6FdkiWiXdnfui)i+j4d1i-i/eMjN9Zi?i/fAi;i{i%5kedi gJ90j69PeCbKjb12jd1U0T0Vh6h0h30Yje370f3!0ZfYjufGd7g16Gf;g(ewjDk6hKf}h@f iKhz3le~jzjEkgg$iP8?f8g+86b`94gi9ai^gn1N2$2J0OjLi5h.d{e$jSc0jsaEfBj85PiJk2iL0%fKkig(fOk8igfSkp9Lg-a3g/a.hug@bpalan9h1-jqb1gEi*awawg~46fYh1h40:k=8^0m2E0h0y8^a auk08(ke7(f{kShD6`kljA7=f{geb g:hLa;1,8^0hhp2Jk{kI0xa_b00N0_0ub5behnlqhq0?j_0Ljjhj0:2G0-l7kdkOkf76k5ld8@kVg6lSa+bKlliXarath0luk{az0waBa|aD0?0SfXlyaEa~jo0xaDa iA3vkNf.g17klTlX28iSf1m3lZ90l#fa24b40t0!1}hrbkg_k(ajlO0Eib3m7wm4m8hFb:lg7uhKb^e/e1eWbSfyh*2fh,i/lufBmomq3NidmpiflXiilWm8iljHa390j-04jdg{2C0c3!9i0T2D2FlJhkhmkB0Egrlyapk{dT4em0jwmriNmQkm7jiRmUf6m mzjJmBkBmDhTebbWi@kGdRm{j%b dpipjZirdZe9i4eWizmFcc25dEkGdHiFnpl~e@9!jYj99Lnmdri|3}e)kCiY53dxgol~nP31dCnxkCnEh-eSnDbVd;nGkMepl9mrjyn1mx7jjCmwkj7)kae{lQ7(eslclXk7n?g!7?n8mYb m!jd0Q0_0Kaqb8l*0.b90L0K0+loh9aHj}fYaK0?0T1h2Jha0xkJi9n+n{mrkhn/n@f3n57 82o4nU1:nJgNc1cFnYn%fxnLc0i3e=3PbQnuoSe0mKi;kL5(m}bvm2kRoCo2kUo1ldkXlmn9e7h:k;jMnBeOngo|e(oNc=oPc%12jUi^gOnsjXncj$iBd(j2eKj)cHoJ0}o70Ely0Tobas37kImMn,0i8nmtn6pvf@oF8mlimXeDfugpgr2fguhPmIp7o_h=itnoivh~nze5pRp0oUp3i79Dpj01plpHg~pJ1-ov0?pLoxh#mN8wpx7 p?m7pyp?a+kbi6lPm1iL8Fp@8mm6pB8EgYimnlcc0.fYnTeSnbp:e+0X8$8J8X8L8U1l0J8Oqq2W2R0T1+qn0X8M9(0-0/0;0x04.
# Tests(insensible à la casse)(Ctrl+I)
(Alt+: ; Ctrl pour inverser les colonnes)
(Esc)