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ù_4:2!-.Sw3/]+7bçpPiqIo1tl(9 ;=vm6ju8Rsèfrgà e[hcé05a,nkydx)050)0T0z0!0u0A0N0D0W0A0!0N0N0F010z0u0s010406050N0K0H0H0!0Q0(040j0x0A0K0 0x0$050m16181a1c140s04051s1l1v0m1s140)0u0G0@0_0{0}0_0$0R0K0!0R0T0h0s0(0z0V1j0D0V0u0R0V0A1X0V0z12050/0q0A0T1E0`0|011W1Y1!1Y0z1*1,1(0z0Q1t1S0@1f0N0s0!0$0}0f011.1G010P0;0T0$0!0H0T1(23252a1:2d1,2g2i120a0D0t0Q0x0s0x0N0u1i0$0D0-210Q0Q0T0W2D1l2l0$1t0m1S2Q1}1 1~1)0)2n1H0u0$2f2A1(1B1D0^1/2!2$0$0x2*1(0s2J1t2O2Q2`15242E2,2b2:0Q190A1(0!1V2J0P0}030c0c0W2;0T1!2/0x0h0y3l120D0y1l0!2{2~132}2m301:323436380T3a013c3e3g3i2%3l0h28040D0f3r3t253v2O2Z013A0!351t370V393b3d3f0-3K2:3M0l3o0l3S2N3u143W3y0}3Z3#053%3)3G3+3J2#3L3m0d3o0d3@1m3_3w2 1F3z0x333!3C3(3E3*3I3-463/3m0Z3o0Z4c2`3`2~3X3~4m423H3,3h4s3k3m0I3o0I4y4e3{4h3}4j3B3$3D3F4G453j3M0p3o0p4P3U4A3x4S3Y4U4l4W4n4Y444r4#3m0L3o0L4*2P4,4g2-4/4k3 414o434q4I4`0h0C3o0C4 3V4B3|544V404X4p4H3.4K3l0Y120y0Y5h514C4:565o595q4J3M0y0y5v3q0m3s3^4+4f5A554E584Z4_473l3O0y3R5M3T505Q5k4D4=4F4^5b5X0y3;045;5y5)4.5+5n4?5p4!5:495?4b5$5O5(4R535{574@5a5r5H4v5?4x644d5P67315B5T6b5F5c0y4M5?4O6i4z5_686n5,5U5.6d3m0y4%5?4)6w4Q5j5`6A5|5-6c5G6F4|5?4~6K6k6M6z5S6B6p5 4t3l5e5?5g6X666Z6m6#6P6C6R5c0f5u046`5^6l4i6=6a5~5W6)0f5J6|5L5N6j6/4-6!5m725E6(5s0f3O7k6~6:707f5D5V5/755=0f3?6.5i7d6;7q5}7h747j610f637a6x6 4T717r6D6S3N6f0f6h7K6L7A7p4;6?6%7F3M0f6t7)7n7Y7N7C6Q6q5X0f6H7?7,527B7!7g7s6E3N6U0f6W7W6Y7-5l7|7P6^7=6+0f6-847c7`7Z5C7D7~7R0l6{8n7_5R7/6@7;6)0l778w8q5*6O7}7Q5c0l3O8F5h1w2^1l2*2T0)1 2Y5k4H2)1C1t2@0T2_3u651t4H8Y2m0u0)0}3d2O5H3C8)8+8a6)5J0D2r0T8;8u5s773@7M010%120-0P8!6y2b0k3o96900$0P120G0x0u2B2g1N9b7o0}11040B9m860$121k7b8%8h9o120#8!0D973z121@2$9s9z019p9C9x9E9c123f0A1j9J9x9F9A040+0e8!149X3W8:018,2~7(8/8*9,8=7j298_8{7i9/2Q5N90993P0Da29K3X0N0)12020v0K0x0z0Ea9abadafac0E0D0M2f9g0u1-0_0D1!0N0z1-0-0?3f4j0)9V0X0T0?ax0Dao9jaFaq370W0`0T9%a49+9-253:9:9`7%3m3;8^2h8`9=8|aV9}9ya5a7a1a2a:0D0B9I0T0#219U0$2$0+0D2f0D0R0O0Q250zasaE0@aO0?160Qb70?0qaA0N0i0Daiahaaajbl0EaQ9)4BaS0c8-48aWa(9{bxa#2iaX7t5s613Sa;9Y3Y9f9haJ9DbK0x120FbP909p0U0nbr2|9*9;aT0$3M6f5nbua)4u9^a$bE7 b*5$bJ9092040P4jbU9nbL040Ab~860xa02#c39L0$0q12b41JaPbs869p9rcgc9cb04190*a45kcicq4.0H0u125xck3X9Nc84C9H1X9W2`9Qb bR040hcC5kcv5vct539p0+9OcHbKca12cv9wb!b cscz5*9vcR2bcB9PcXcE0RcG3ucIc4120ocNcucw6|c,1:cT9#bZ8Zb#8;bw0h6tb+b$9?3M4MbCa%8D5Xdab@a;a:bKb`b|0Qc|689Sds2bc512c7c/9ccmcd9lc)4.c(c$9tcmcod09ZcjdI9LcP04cydPcA9Bdv9G049T9VcfcW90cKcMdAb dR5LdUcr12cUdX3}dKdzd/dG12dOd5b 9u04c#d~chdWd+9t9S1fd#d?01cKc{e6dQc~5#d`cSd;d39x9(dUbud86Hdbb;7R4%dgeu5cesdldmdmdody95efdV9qdMc0c2dFek04cVc@c:dZeKcTebcK0gbTeHd:eJeN31c;c?3UbKc.d%d e8a{e*2Pe,d;9$enaRdcd86UetbzaY0h4|exf0bF3Me~eBeCfaeSaI2#0NeKcK0ieKe00!0s0s2f0)eUd|d}e+9Rc1fqePebe00Wfw0+0+d4ftbte|9.3m6+e di6)5ef4fM5sfKf9eE042J0z0K0Qe23Uc^c9bM9ifefEe?d69=d85wbyfQ5H5ufPdd6F6{3Seoe32EeqfI3l8~37b,bAg2b/bDf57 5I1(64b_933EeKa09Ee%3z9e042#0W2J2i0$av0cfd0$ffgldNfj120R0Q0;1,fweQf#eSa@gHfye:eagz9Me^f+a,g0aU6F3OfLf_5Yg8dhg!5!gd9~b gjdngQa6a8bnbmagaeg=ak0w0$gq0Xgsav2F1-0y0D0z0x1hb81,aybaaHbN46aF02030l0C0E0K2$0Dbg0H0q0Tbjbphtg_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`czhy5HbHg4dchD0y49f^igbHfTgfb{b}e!5`9HgMiqdteTiudwc6f!h{fchYhQh#e#e_6xiafHgW3lb*ieey5:4vijg60yb?3sfah|4.b`0ueGhVhNh;0AgGh 120UgBfvi,040ni.gQfzfwbYix1:eXhUi1cJ12d*ej2bd-fwiHj0860W77030D2B0@1-0$hghi0EaEb6240?hl1-hohqhwf-b%5HdaiOhH6rdfhGf=6FdkiWiXdnfui)i+j4d1i-i/eMjN9Zi?i/fAi;i{i%5kedi gJ90j69PeCbKjb12jd1U0!0Jh6h0h30Sje370G3!0TfYjufGd7g16Gf;g(ewjDk6hKf}h@f iKhz3le~jzjEkgg$iP8?f8g+86b`94gi9ai^gn1N2$2J0cjLi5h.d{e$jSc0jsaEfBj85PiJk2iL0yfKkig(fOk8igfSkp9Lg-a3g/a.hug@bpalan9h1-jqb1gEi*awawg~46fYh1h40:k=8^0*2E0x0b8^a auk08(ke7(f{kShD6`kljA7=f{geb g:hLa;1,8^0xhp2Jk{kI0Na_b00s0_0rb5behnlqhq0?j_0Ajjhj0:2G0-l7kdkOkf76k5ld8@kVg6lSa+bKlliXarath0luk{az0QaBa|aD0?0BfXlyaEa~jo0NaDa iA3vkNf.g17klTlX28iSf1m3lZ90l#fa24b40H0O1}hrbkg_k(ajlO0Dib3m7wm4m8hFb:lg7uhKb^e/e1eWbSfyh*2fh,i/lufBmomq3NidmpiflXiilWm8iljHa390j-04jdg{2C0u3!9i0!2D2FlJhkhmkB0Dgrlyapk{dT4em0jwmriNmQkm7jiRmUf6m mzjJmBkBmDhTebbWi@kGdRm{j%b dpipjZirdZe9i4eWizmFcc25dEkGdHiFnpl~e@9!jYj99Lnmdri|3}e)kCiY53dxgol~nP31dCnxkCnEh-eSnDbVd;nGkMepl9mrjyn1mx7jjCmwkj7)kae{lQ7(eslclXk7n?g!7?n8mYb m!jd0t0_0Waqb8l*0.b90A0W0Kloh9aHj}fYaK0?0!1h2Jha0NkJi9n+n{mrkhn/n@f3n57 82o4nU1:nJgNc1cFnYn%fxnLc0i3e=3PbQnuoSe0mKi;kL5(m}bvm2kRoCo2kUo1ldkXlmn9e7h:k;jMnBeOngo|e(oNc=oPc%12jUi^gOnsjXncj$iBd(j2eKj)cHoJ0}o70Dly0!obas37kImMn,0h8nmtn6pvf@oF8mlimXeDfugpgr2fguhPmIp7o_h=itnoivh~nze5pRp0oUp3i79Dpj01plpHg~pJ1-ov0?pLoxh#mN8wpx7 p?m7pyp?a+kbi6lPm1iL8Fp@8mm6pB8EgYimnlcc0.fYnTeSnbp:e+0m8$8J8X8L8U1l0z8Oqq2W2R0!1+qn0m8M9(0-0/0;0N04.
# Tests
(insensible Ă la casse)(Ctrl+I)
(Alt+: ; Ctrl pour inverser les colonnes)
(Esc)