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.
.128013So4l7s_60:w+pPnù[1cji)-e3,(v];uyqçRx./hIgk2=èàtfra98d é!m5b050#0y0V0Y0v0e0g0$0t0e0Y0g0g0S010V0v0n010406050g0F0)0)0Y0X0G040b0c0e0F0 0c0p050M16181a1c140n04051s1l1v0M1s140#0v0C0@0_0{0}0_0p0P0F0Y0P0y0x0n0G0V0N1j0$0N0v0P0N0e1X0N0V12050/0+0e0y1E0`0|011W1Y1!1Y0V1*1,1(0V0X1t1S0@1f0g0n0Y0p0}0R011.1G010W0;0y0p0Y0)0y1(23252a1:2d1,2g2i120a0$0o0X0c0n0c0g0v1i0p0$0-210X0X0y0t2D1l2l0p1t0M1S2Q1}1 1~1)0#2n1H0v0p2f2A1(1B1D0^1/2!2$0p0c2*1(0n2J1t2O2Q2`15242E2,2b2:0X190e1(0Y1V2J0W0}030h0h0t2;0y1!2/0c0x0s3l120$0s1l0Y2{2~132}2m301:323436380y3a013c3e3g3i2%3l0x28040$0R3r3t253v2O2Z013A0Y351t370N393b3d3f0-3K2:3M0z3o0z3S2N3u143W3y0}3Z3#053%3)3G3+3J2#3L3m0d3o0d3@1m3_3w2 1F3z0c333!3C3(3E3*3I3-463/3m0*3o0*4c2`3`2~3X3~4m423H3,3h4s3k3m0i3o0i4y4e3{4h3}4j3B3$3D3F4G453j3M0f3o0f4P3U4A3x4S3Y4U4l4W4n4Y444r4#3m0!3o0!4*2P4,4g2-4/4k3 414o434q4I4`0x0Z3o0Z4 3V4B3|544V404X4p4H3.4K3l0j120s0j5h514C4:565o595q4J3M0s0s5v3q0M3s3^4+4f5A554E584Z4_473l3O0s3R5M3T505Q5k4D4=4F4^5b5X0s3;045;5y5)4.5+5n4?5p4!5:495?4b5$5O5(4R535{574@5a5r5H4v5?4x644d5P67315B5T6b5F5c0s4M5?4O6i4z5_686n5,5U5.6d3m0s4%5?4)6w4Q5j5`6A5|5-6c5G6F4|5?4~6K6k6M6z5S6B6p5 4t3l5e5?5g6X666Z6m6#6P6C6R5c0R5u046`5^6l4i6=6a5~5W6)0R5J6|5L5N6j6/4-6!5m725E6(5s0R3O7k6~6:707f5D5V5/755=0R3?6.5i7d6;7q5}7h747j610R637a6x6 4T717r6D6S3N6f0R6h7K6L7A7p4;6?6%7F3M0R6t7)7n7Y7N7C6Q6q5X0R6H7?7,527B7!7g7s6E3N6U0R6W7W6Y7-5l7|7P6^7=6+0R6-847c7`7Z5C7D7~7R0z6{8n7_5R7/6@7;6)0z778w8q5*6O7}7Q5c0z3O8F5h1w2^1l2*2T0#1 2Y5k4H2)1C1t2@0y2_3u651t4H8Y2m0v0#0}3d2O5H3C8)8+8a6)5J0$2r0y8;8u5s773@7M010Q120-0W8!6y2b0l3o96900p0W120C0c0v2B2g1N9b7o0}11040B9m860p121k7b8%8h9o120A8!0$973z121@2$9s9z019p9C9x9E9c123f0e1j9J9x9F9A040w0k8!149X3W8:018,2~7(8/8*9,8=7j298_8{7i9/2Q5N90993P0$a29K3X0g0#12020H0F0c0V0Ea9abadafac0E0$0J2f9g0v1-0_0$1!0g0V1-0-0?3f4j0#9V0%0y0?ax0$ao9jaFaq370t0`0y9%a49+9-253:9:9`7%3m3;8^2h8`9=8|aV9}9ya5a7a1a2a:0$0B9I0y0A219U0p2$0w0$2f0$0P0T0X250VasaE0@aO0?160Xb70?0+aA0g0L0$aiahaaajbl0EaQ9)4BaS0h8-48aWa(9{bxa#2iaX7t5s613Sa;9Y3Y9f9haJ9DbK0c120SbP909p0r0Dbr2|9*9;aT0p3M6f5nbua)4u9^a$bE7 b*5$bJ9092040W4jbU9nbL040eb~860ca02#c39L0p0+12b41JaPbs869p9rcgc9cb04190Ka45kcicq4.0)0v125xck3X9Nc84C9H1X9W2`9Qb bR040xcC5kcv5vct539p0w9OcHbKca12cv9wb!b cscz5*9vcR2bcB9PcXcE0PcG3ucIc4120mcNcucw6|c,1:cT9#bZ8Zb#8;bw0x6tb+b$9?3M4MbCa%8D5Xdab@a;a:bKb`b|0Xc|689Sds2bc512c7c/9ccmcd9lc)4.c(c$9tcmcod09ZcjdI9LcP04cydPcA9Bdv9G049T9VcfcW90cKcMdAb dR5LdUcr12cUdX3}dKdzd/dG12dOd5b 9u04c#d~chdWd+9t9S1fd#d?01cKc{e6dQc~5#d`cSd;d39x9(dUbud86Hdbb;7R4%dgeu5cesdldmdmdody95efdV9qdMc0c2dFek04cVc@c:dZeKcTebcK0(bTeHd:eJeN31c;c?3UbKc.d%d e8a{e*2Pe,d;9$enaRdcd86UetbzaY0x4|exf0bF3Me~eBeCfaeSaI2#0geKcK0LeKe00Y0n0n2f0#eUd|d}e+9Rc1fqePebe00tfw0w0wd4ftbte|9.3m6+e di6)5ef4fM5sfKf9eE042J0V0F0Xe23Uc^c9bM9ifefEe?d69=d85wbyfQ5H5ufPdd6F6{3Seoe32EeqfI3l8~37b,bAg2b/bDf57 5I1(64b_933EeKa09Ee%3z9e042#0t2J2i0pav0hfd0pffgldNfj120P0X0;1,fweQf#eSa@gHfye:eagz9Me^f+a,g0aU6F3OfLf_5Yg8dhg!5!gd9~b gjdngQa6a8bnbmagaeg=ak0O0pgq0%gsav2F1-0s0$0V0c1hb81,aybaaHbN46aF02030z0Z0E0F2$0$bg0)0+0ybjbphtg_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`czhy5HbHg4dchD0s49f^igbHfTgfb{b}e!5`9HgMiqdteTiudwc6f!h{fchYhQh#e#e_6xiafHgW3lb*ieey5:4vijg60sb?3sfah|4.b`0veGhVhNh;0egGh 120rgBfvi,040Di.gQfzfwbYix1:eXhUi1cJ12d*ej2bd-fwiHj0860t77030$2B0@1-0phghi0EaEb6240?hl1-hohqhwf-b%5HdaiOhH6rdfhGf=6FdkiWiXdnfui)i+j4d1i-i/eMjN9Zi?i/fAi;i{i%5kedi gJ90j69PeCbKjb12jd1U0Y0uh6h0h30Uje370C3!0yfYjufGd7g16Gf;g(ewjDk6hKf}h@f iKhz3le~jzjEkgg$iP8?f8g+86b`94gi9ai^gn1N2$2J0hjLi5h.d{e$jSc0jsaEfBj85PiJk2iL0sfKkig(fOk8igfSkp9Lg-a3g/a.hug@bpalan9h1-jqb1gEi*awawg~46fYh1h40:k=8^0K2E0c0q8^a auk08(ke7(f{kShD6`kljA7=f{geb g:hLa;1,8^0chp2Jk{kI0ga_b00n0_0Ib5behnlqhq0?j_0ejjhj0:2G0-l7kdkOkf76k5ld8@kVg6lSa+bKlliXarath0luk{az0XaBa|aD0?0BfXlyaEa~jo0gaDa iA3vkNf.g17klTlX28iSf1m3lZ90l#fa24b40)0T1}hrbkg_k(ajlO0$ib3m7wm4m8hFb:lg7uhKb^e/e1eWbSfyh*2fh,i/lufBmomq3NidmpiflXiilWm8iljHa390j-04jdg{2C0v3!9i0Y2D2FlJhkhmkB0$grlyapk{dT4em0jwmriNmQkm7jiRmUf6m mzjJmBkBmDhTebbWi@kGdRm{j%b dpipjZirdZe9i4eWizmFcc25dEkGdHiFnpl~e@9!jYj99Lnmdri|3}e)kCiY53dxgol~nP31dCnxkCnEh-eSnDbVd;nGkMepl9mrjyn1mx7jjCmwkj7)kae{lQ7(eslclXk7n?g!7?n8mYb m!jd0o0_0taqb8l*0.b90e0t0Floh9aHj}fYaK0?0Y1h2Jha0gkJi9n+n{mrkhn/n@f3n57 82o4nU1:nJgNc1cFnYn%fxnLc0i3e=3PbQnuoSe0mKi;kL5(m}bvm2kRoCo2kUo1ldkXlmn9e7h:k;jMnBeOngo|e(oNc=oPc%12jUi^gOnsjXncj$iBd(j2eKj)cHoJ0}o70$ly0Yobas37kImMn,0x8nmtn6pvf@oF8mlimXeDfugpgr2fguhPmIp7o_h=itnoivh~nze5pRp0oUp3i79Dpj01plpHg~pJ1-ov0?pLoxh#mN8wpx7 p?m7pyp?a+kbi6lPm1iL8Fp@8mm6pB8EgYimnlcc0.fYnTeSnbp:e+0M8$8J8X8L8U1l0V8Oqq2W2R0Y1+qn0M8M9(0-0/0;0g04.
# Tests(insensible à la casse)(Ctrl+I)
(Alt+: ; Ctrl pour inverser les colonnes)
(Esc)