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_kySl2ph=d,RjInù +/7(b6u.:3a-eç9éo]1èm!0g4)s8iqvP;fàr5x[cwt050k0E0+0C0U0f0S0r0)0f0C0S0S0j010+0U0h010406050S0y0M0M0C0#0d040e0I0f0y0 0I0p050t16181a1c140h04051s1l1v0t1s140k0U0W0@0_0{0}0_0p0P0y0C0P0E0D0h0d0+0i1j0r0i0U0P0i0f1X0i0+12050/0w0f0E1E0`0|011W1Y1!1Y0+1*1,1(0+0#1t1S0@1f0S0h0C0p0}0g011.1G010Z0;0E0p0C0M0E1(23252a1:2d1,2g2i120a0r0X0#0I0h0I0S0U1i0p0r0-210#0#0E0)2D1l2l0p1t0t1S2Q1}1 1~1)0k2n1H0U0p2f2A1(1B1D0^1/2!2$0p0I2*1(0h2J1t2O2Q2`15242E2,2b2:0#190f1(0C1V2J0Z0}030b0b0)2;0E1!2/0I0D0K3l120r0K1l0C2{2~132}2m301:323436380E3a013c3e3g3i2%3l0D28040r0g3r3t253v2O2Z013A0C351t370i393b3d3f0-3K2:3M0B3o0B3S2N3u143W3y0}3Z3#053%3)3G3+3J2#3L3m0Q3o0Q3@1m3_3w2 1F3z0I333!3C3(3E3*3I3-463/3m0$3o0$4c2`3`2~3X3~4m423H3,3h4s3k3m0x3o0x4y4e3{4h3}4j3B3$3D3F4G453j3M0u3o0u4P3U4A3x4S3Y4U4l4W4n4Y444r4#3m0T3o0T4*2P4,4g2-4/4k3 414o434q4I4`0D0G3o0G4 3V4B3|544V404X4p4H3.4K3l0O120K0O5h514C4:565o595q4J3M0K0K5v3q0t3s3^4+4f5A554E584Z4_473l3O0K3R5M3T505Q5k4D4=4F4^5b5X0K3;045;5y5)4.5+5n4?5p4!5:495?4b5$5O5(4R535{574@5a5r5H4v5?4x644d5P67315B5T6b5F5c0K4M5?4O6i4z5_686n5,5U5.6d3m0K4%5?4)6w4Q5j5`6A5|5-6c5G6F4|5?4~6K6k6M6z5S6B6p5 4t3l5e5?5g6X666Z6m6#6P6C6R5c0g5u046`5^6l4i6=6a5~5W6)0g5J6|5L5N6j6/4-6!5m725E6(5s0g3O7k6~6:707f5D5V5/755=0g3?6.5i7d6;7q5}7h747j610g637a6x6 4T717r6D6S3N6f0g6h7K6L7A7p4;6?6%7F3M0g6t7)7n7Y7N7C6Q6q5X0g6H7?7,527B7!7g7s6E3N6U0g6W7W6Y7-5l7|7P6^7=6+0g6-847c7`7Z5C7D7~7R0B6{8n7_5R7/6@7;6)0B778w8q5*6O7}7Q5c0B3O8F5h1w2^1l2*2T0k1 2Y5k4H2)1C1t2@0E2_3u651t4H8Y2m0U0k0}3d2O5H3C8)8+8a6)5J0r2r0E8;8u5s773@7M010c120-0Z8!6y2b0*3o96900p0Z120W0I0U2B2g1N9b7o0}11040v9m860p121k7b8%8h9o120l8!0r973z121@2$9s9z019p9C9x9E9c123f0f1j9J9x9F9A040R0A8!149X3W8:018,2~7(8/8*9,8=7j298_8{7i9/2Q5N90993P0ra29K3X0S0k12020V0y0I0+0Ya9abadafac0Y0r0m2f9g0U1-0_0r1!0S0+1-0-0?3f4j0k9V0H0E0?ax0rao9jaFaq370)0`0E9%a49+9-253:9:9`7%3m3;8^2h8`9=8|aV9}9ya5a7a1a2a:0r0v9I0E0l219U0p2$0R0r2f0r0P0L0#250+asaE0@aO0?160#b70?0waA0S0z0raiahaaajbl0YaQ9)4BaS0b8-48aWa(9{bxa#2iaX7t5s613Sa;9Y3Y9f9haJ9DbK0I120jbP909p0(0Jbr2|9*9;aT0p3M6f5nbua)4u9^a$bE7 b*5$bJ9092040Z4jbU9nbL040fb~860Ia02#c39L0p0w12b41JaPbs869p9rcgc9cb04190%a45kcicq4.0M0U125xck3X9Nc84C9H1X9W2`9Qb bR040DcC5kcv5vct539p0R9OcHbKca12cv9wb!b cscz5*9vcR2bcB9PcXcE0PcG3ucIc4120scNcucw6|c,1:cT9#bZ8Zb#8;bw0D6tb+b$9?3M4MbCa%8D5Xdab@a;a:bKb`b|0#c|689Sds2bc512c7c/9ccmcd9lc)4.c(c$9tcmcod09ZcjdI9LcP04cydPcA9Bdv9G049T9VcfcW90cKcMdAb dR5LdUcr12cUdX3}dKdzd/dG12dOd5b 9u04c#d~chdWd+9t9S1fd#d?01cKc{e6dQc~5#d`cSd;d39x9(dUbud86Hdbb;7R4%dgeu5cesdldmdmdody95efdV9qdMc0c2dFek04cVc@c:dZeKcTebcK0NbTeHd:eJeN31c;c?3UbKc.d%d e8a{e*2Pe,d;9$enaRdcd86UetbzaY0D4|exf0bF3Me~eBeCfaeSaI2#0SeKcK0zeKe00C0h0h2f0keUd|d}e+9Rc1fqePebe00)fw0R0Rd4ftbte|9.3m6+e di6)5ef4fM5sfKf9eE042J0+0y0#e23Uc^c9bM9ifefEe?d69=d85wbyfQ5H5ufPdd6F6{3Seoe32EeqfI3l8~37b,bAg2b/bDf57 5I1(64b_933EeKa09Ee%3z9e042#0)2J2i0pav0bfd0pffgldNfj120P0#0;1,fweQf#eSa@gHfye:eagz9Me^f+a,g0aU6F3OfLf_5Yg8dhg!5!gd9~b gjdngQa6a8bnbmagaeg=ak0o0pgq0Hgsav2F1-0K0r0+0I1hb81,aybaaHbN46aF02030B0G0Y0y2$0rbg0M0w0Ebjbphtg_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`czhy5HbHg4dchD0K49f^igbHfTgfb{b}e!5`9HgMiqdteTiudwc6f!h{fchYhQh#e#e_6xiafHgW3lb*ieey5:4vijg60Kb?3sfah|4.b`0UeGhVhNh;0fgGh 120(gBfvi,040Ji.gQfzfwbYix1:eXhUi1cJ12d*ej2bd-fwiHj0860)77030r2B0@1-0phghi0YaEb6240?hl1-hohqhwf-b%5HdaiOhH6rdfhGf=6FdkiWiXdnfui)i+j4d1i-i/eMjN9Zi?i/fAi;i{i%5kedi gJ90j69PeCbKjb12jd1U0C0nh6h0h30!je370W3!0EfYjufGd7g16Gf;g(ewjDk6hKf}h@f iKhz3le~jzjEkgg$iP8?f8g+86b`94gi9ai^gn1N2$2J0bjLi5h.d{e$jSc0jsaEfBj85PiJk2iL0KfKkig(fOk8igfSkp9Lg-a3g/a.hug@bpalan9h1-jqb1gEi*awawg~46fYh1h40:k=8^0%2E0I0q8^a auk08(ke7(f{kShD6`kljA7=f{geb g:hLa;1,8^0Ihp2Jk{kI0Sa_b00h0_0Fb5behnlqhq0?j_0fjjhj0:2G0-l7kdkOkf76k5ld8@kVg6lSa+bKlliXarath0luk{az0#aBa|aD0?0vfXlyaEa~jo0SaDa iA3vkNf.g17klTlX28iSf1m3lZ90l#fa24b40M0L1}hrbkg_k(ajlO0rib3m7wm4m8hFb:lg7uhKb^e/e1eWbSfyh*2fh,i/lufBmomq3NidmpiflXiilWm8iljHa390j-04jdg{2C0U3!9i0C2D2FlJhkhmkB0rgrlyapk{dT4em0jwmriNmQkm7jiRmUf6m mzjJmBkBmDhTebbWi@kGdRm{j%b dpipjZirdZe9i4eWizmFcc25dEkGdHiFnpl~e@9!jYj99Lnmdri|3}e)kCiY53dxgol~nP31dCnxkCnEh-eSnDbVd;nGkMepl9mrjyn1mx7jjCmwkj7)kae{lQ7(eslclXk7n?g!7?n8mYb m!jd0X0_0)aqb8l*0.b90f0)0yloh9aHj}fYaK0?0C1h2Jha0SkJi9n+n{mrkhn/n@f3n57 82o4nU1:nJgNc1cFnYn%fxnLc0i3e=3PbQnuoSe0mKi;kL5(m}bvm2kRoCo2kUo1ldkXlmn9e7h:k;jMnBeOngo|e(oNc=oPc%12jUi^gOnsjXncj$iBd(j2eKj)cHoJ0}o70rly0Cobas37kImMn,0D8nmtn6pvf@oF8mlimXeDfugpgr2fguhPmIp7o_h=itnoivh~nze5pRp0oUp3i79Dpj01plpHg~pJ1-ov0?pLoxh#mN8wpx7 p?m7pyp?a+kbi6lPm1iL8Fp@8mm6pB8EgYimnlcc0.fYnTeSnbp:e+0t8$8J8X8L8U1l0+8Oqq2W2R0C1+qn0t8M9(0-0/0;0S04.
# Tests(insensible à la casse)(Ctrl+I)
(Alt+: ; Ctrl pour inverser les colonnes)
(Esc)