ajout TP3
This commit is contained in:
63
TP1&TP2/compteur/MiniMax_versionMemoisation_compteur.java
Normal file
63
TP1&TP2/compteur/MiniMax_versionMemoisation_compteur.java
Normal file
@@ -0,0 +1,63 @@
|
||||
import java.util.ArrayList;
|
||||
public class MiniMax_versionMemoisation_compteur{
|
||||
|
||||
private static ArrayList<Integer> max = new ArrayList<Integer>();
|
||||
private static ArrayList<Integer> min = new ArrayList<Integer>();
|
||||
private static int Allumete;
|
||||
public static int compteur_noeud = 0;
|
||||
|
||||
public MiniMax_versionMemoisation_compteur(int n){
|
||||
Allumete = n;
|
||||
for(int i=0;i<n;i++){
|
||||
max.add(-2);
|
||||
min.add(-2);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
public static int explorMax(int nbAllumete){
|
||||
compteur_noeud++;
|
||||
if (nbAllumete <=0){
|
||||
return +1;
|
||||
}
|
||||
if (max.get(nbAllumete)!=-2){
|
||||
return max.get(nbAllumete);
|
||||
}
|
||||
int meilleurRes = -2;
|
||||
for (int coup =1;coup <=3;coup ++){
|
||||
int res = explorMin(nbAllumete-coup);
|
||||
if (meilleurRes < res){
|
||||
meilleurRes =res;
|
||||
}
|
||||
}
|
||||
max.set(nbAllumete,meilleurRes);
|
||||
return meilleurRes;
|
||||
}
|
||||
|
||||
|
||||
public static int explorMin(int nbAllumete){
|
||||
compteur_noeud++;
|
||||
if (nbAllumete <=0){
|
||||
return -1;
|
||||
}
|
||||
if (min.get(nbAllumete)!=-2){
|
||||
return min.get(nbAllumete);
|
||||
}
|
||||
|
||||
int mepireRes = 2;
|
||||
for (int coup =1;coup <=3;coup ++){
|
||||
int res = explorMax(nbAllumete-coup);
|
||||
if ( res < mepireRes){
|
||||
mepireRes = res;
|
||||
}
|
||||
}
|
||||
min.set(nbAllumete,mepireRes);
|
||||
return mepireRes;
|
||||
}
|
||||
|
||||
public static void main(String[]arg){
|
||||
MiniMax_versionMemoisation_compteur newCLass = new MiniMax_versionMemoisation_compteur(32);
|
||||
System.out.println(explorMax(31));
|
||||
System.out.println(compteur_noeud);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user