Class: DSubset
Overview
Technique Disjoint Subset.
Class Method Summary collapse
-
.creer ⇒ Object
Constructeur de la classe DSubset.
Instance Method Summary collapse
-
#combienEtape ⇒ Object
Retourne le nombre d'étape pour faire la technique.
-
#etape(n) ⇒ Object
Retourne les étapes pour faire la technique.
-
#solution(grille) ⇒ Object
Recherche une solution pour la technique utilisée.
Class Method Details
.creer ⇒ Object
Constructeur de la classe DSubset
12 13 14 |
# File 'app/utils/DSubset.rb', line 12 def DSubset.creer() new() end |
Instance Method Details
#combienEtape ⇒ Object
Retourne le nombre d'étape pour faire la technique
71 72 73 |
# File 'app/utils/DSubset.rb', line 71 def combienEtape() return 4 end |
#etape(n) ⇒ Object
Retourne les étapes pour faire la technique
82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 |
# File 'app/utils/DSubset.rb', line 82 def etape(n) case(n) when 1 return "Bienvenue sur l'explication de la technique "+self.class.to_s+"." when 2 return "Recherchez les candidats possibles pour chaque case d'une ligne/colonne." when 3 return "Il arrive que N candicats soient possibles sur N cases d'une même ligne/colonne" when 4 return "Dans ce cas, les N candidats sont applicable uniquement dans ces N cases et non ailleur." end return nil end |
#solution(grille) ⇒ Object
Recherche une solution pour la technique utilisée
23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 |
# File 'app/utils/DSubset.rb', line 23 def solution(grille) grilleIndice = indice(grille) res = Array.new() [0,1,2,3,4,5,6,7,8].each { |x| col = colonne(grilleIndice,x) col.each_with_index{ |c,y| i = 0 c.each_value{|v| if v == true then i+=1 end } if i>1 then res << [x,y] col[(y+1)..(-1)].each_with_index{ |cBis,yBis| if cBis.eql?(c) then res << [x,y+yBis+1] end } if res.length == i then return res end end res = Array.new() } } [0,1,2,3,4,5,6,7,8].each { |y| lig = ligne(grilleIndice,y) lig.each_with_index{ |c,x| i = 0 c.each_value{|v| if v == true then i+=1 end } if i>1 then res << [x,y] lig[(x+1)..(-1)].each_with_index{|cBis,xBis| if cBis.eql?(c) then res << [x+xBis+1,y] end } if res.length == i then return res end end res = Array.new() } } return nil end |