fin arbre
This commit is contained in:
Binary file not shown.
@@ -1,56 +0,0 @@
|
||||
public class Arithmetique {
|
||||
|
||||
public static void main(String[] args) {
|
||||
if (args.length == 0) {
|
||||
System.out.println("Veuillez fournir une expression en notation polonaise inversée.");
|
||||
return;
|
||||
}
|
||||
|
||||
// Utilisation de l'implémentation FileTableau pour la file
|
||||
File<Integer> queue = new FileTableau<>();
|
||||
|
||||
try {
|
||||
for (String token : args) {
|
||||
switch (token) {
|
||||
case "+":
|
||||
// Addition
|
||||
queue.ajouter(queue.retirer() + queue.retirer());
|
||||
break;
|
||||
case "-":
|
||||
// Soustraction (attention à l'ordre)
|
||||
int b = queue.retirer();
|
||||
int a = queue.retirer();
|
||||
queue.ajouter(a - b);
|
||||
break;
|
||||
case "x":
|
||||
// Multiplication
|
||||
queue.ajouter(queue.retirer() * queue.retirer());
|
||||
break;
|
||||
case "/":
|
||||
// Division (attention à l'ordre)
|
||||
b = queue.retirer();
|
||||
a = queue.retirer();
|
||||
if (b == 0) {
|
||||
throw new ArithmeticException("Division par zéro");
|
||||
}
|
||||
queue.ajouter(a / b);
|
||||
break;
|
||||
default:
|
||||
// Si ce n'est pas un opérateur, alors c'est un nombre
|
||||
queue.ajouter(Integer.parseInt(token));
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// Le résultat final doit être le seul élément restant dans la file
|
||||
if (queue.taille() == 1) {
|
||||
System.out.println("= " + queue.retirer());
|
||||
} else {
|
||||
System.out.println("Erreur : Expression incorrecte.");
|
||||
}
|
||||
|
||||
} catch (Exception e) {
|
||||
System.out.println("Erreur lors de l'évaluation de l'expression : " + e.getMessage());
|
||||
}
|
||||
}
|
||||
}
|
||||
BIN
DEV3.2/Files/tableau/ArrayQueue$1.class
Normal file
BIN
DEV3.2/Files/tableau/ArrayQueue$1.class
Normal file
Binary file not shown.
BIN
DEV3.2/Files/tableau/ArrayQueue.class
Normal file
BIN
DEV3.2/Files/tableau/ArrayQueue.class
Normal file
Binary file not shown.
93
DEV3.2/Files/tableau/ArrayQueue.java
Normal file
93
DEV3.2/Files/tableau/ArrayQueue.java
Normal file
@@ -0,0 +1,93 @@
|
||||
import java.util.AbstractQueue;
|
||||
import java.util.Iterator;
|
||||
import java.util.NoSuchElementException;
|
||||
|
||||
public class ArrayQueue<E> extends AbstractQueue<E> {
|
||||
|
||||
private static final int INITIAL_CAPACITY = 10; // Taille initiale du tableau
|
||||
private E[] elements; // Tableau contenant les éléments
|
||||
private int head; // Index de la tête de la file
|
||||
private int tail; // Index de la queue de la file
|
||||
private int size; // Nombre d'éléments dans la file
|
||||
|
||||
@SuppressWarnings("unchecked")
|
||||
public ArrayQueue() {
|
||||
elements = (E[]) new Object[INITIAL_CAPACITY];
|
||||
head = 0;
|
||||
tail = 0;
|
||||
size = 0;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean offer(E e) {
|
||||
if (e == null) {
|
||||
throw new NullPointerException("Les éléments null ne sont pas autorisés.");
|
||||
}
|
||||
if (size == elements.length) {
|
||||
redimensionner();
|
||||
}
|
||||
elements[tail] = e;
|
||||
tail = (tail + 1) % elements.length;
|
||||
size++;
|
||||
return true;
|
||||
}
|
||||
|
||||
@Override
|
||||
public E poll() {
|
||||
if (size == 0) {
|
||||
return null;
|
||||
}
|
||||
E element = elements[head];
|
||||
elements[head] = null; // Libération de la référence pour éviter les fuites mémoire
|
||||
head = (head + 1) % elements.length;
|
||||
size--;
|
||||
return element;
|
||||
}
|
||||
|
||||
@Override
|
||||
public E peek() {
|
||||
return (size == 0) ? null : elements[head];
|
||||
}
|
||||
|
||||
@Override
|
||||
public int size() {
|
||||
return size;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Iterator<E> iterator() {
|
||||
return new Iterator<E>() {
|
||||
private int index = head;
|
||||
private int remaining = size;
|
||||
|
||||
@Override
|
||||
public boolean hasNext() {
|
||||
return remaining > 0;
|
||||
}
|
||||
|
||||
@Override
|
||||
public E next() {
|
||||
if (!hasNext()) {
|
||||
throw new NoSuchElementException();
|
||||
}
|
||||
E element = elements[index];
|
||||
index = (index + 1) % elements.length;
|
||||
remaining--;
|
||||
return element;
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
// Méthode privée pour redimensionner le tableau lorsqu'il est plein
|
||||
@SuppressWarnings("unchecked")
|
||||
private void redimensionner() {
|
||||
int newCapacity = elements.length * 2;
|
||||
E[] newElements = (E[]) new Object[newCapacity];
|
||||
for (int i = 0; i < size; i++) {
|
||||
newElements[i] = elements[(head + i) % elements.length];
|
||||
}
|
||||
elements = newElements;
|
||||
head = 0;
|
||||
tail = size;
|
||||
}
|
||||
}
|
||||
Binary file not shown.
@@ -1,6 +0,0 @@
|
||||
public interface File<E> {
|
||||
void ajouter(E element); // Ajoute un élément en fin de la file
|
||||
E retirer(); // Retire et retourne l'élément en tête de la file
|
||||
int taille(); // Retourne la taille de la file
|
||||
boolean estVide(); // Vérifie si la file est vide
|
||||
}
|
||||
Binary file not shown.
@@ -1,41 +0,0 @@
|
||||
public class FileTableau<E> implements File<E> {
|
||||
private static final int CAPACITE_INITIALE = 20;
|
||||
private E[] elements;
|
||||
private int taille = 0;
|
||||
private int debut = 0;
|
||||
private int fin = 0;
|
||||
|
||||
@SuppressWarnings("unchecked")
|
||||
public FileTableau() {
|
||||
elements = (E[]) new Object[CAPACITE_INITIALE]; // Création du tableau initial
|
||||
}
|
||||
|
||||
@Override
|
||||
public void ajouter(E element) {
|
||||
elements[fin] = element;
|
||||
fin = (fin + 1) % elements.length;
|
||||
taille++;
|
||||
}
|
||||
|
||||
@Override
|
||||
public E retirer() {
|
||||
if (estVide()) {
|
||||
throw new IllegalStateException("La file est vide");
|
||||
}
|
||||
E element = elements[debut];
|
||||
elements[debut] = null; // Supprime la référence pour éviter les fuites de mémoire
|
||||
debut = (debut + 1) % elements.length;
|
||||
taille--;
|
||||
return element;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int taille() {
|
||||
return taille;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean estVide() {
|
||||
return taille == 0;
|
||||
}
|
||||
}
|
||||
BIN
DEV3.2/Files/tableau/MergeSortQueue.class
Normal file
BIN
DEV3.2/Files/tableau/MergeSortQueue.class
Normal file
Binary file not shown.
76
DEV3.2/Files/tableau/MergeSortQueue.java
Normal file
76
DEV3.2/Files/tableau/MergeSortQueue.java
Normal file
@@ -0,0 +1,76 @@
|
||||
import java.util.Queue;
|
||||
|
||||
public class MergeSortQueue {
|
||||
|
||||
// Méthode de tri principal qui effectue le tri fusion
|
||||
public static <T extends Comparable<T>> Queue<T> trier(Queue<T> file) {
|
||||
if (file.size() <= 1) {
|
||||
return file;
|
||||
}
|
||||
|
||||
// Séparer la file en deux moitiés
|
||||
Queue<T> file1 = new ArrayQueue<>();
|
||||
Queue<T> file2 = new ArrayQueue<>();
|
||||
scinder(file, file1, file2);
|
||||
|
||||
// Tri de chaque moitié de façon récursive
|
||||
file1 = trier(file1);
|
||||
file2 = trier(file2);
|
||||
|
||||
// Fusion des deux moitiés triées
|
||||
return fusionner(file1, file2);
|
||||
}
|
||||
|
||||
// Méthode pour diviser une file en deux moitiés
|
||||
private static <T> void scinder(Queue<T> source, Queue<T> file1, Queue<T> file2) {
|
||||
int taille = source.size();
|
||||
for (int i = 0; i < taille / 2; i++) {
|
||||
file1.offer(source.poll());
|
||||
}
|
||||
while (!source.isEmpty()) {
|
||||
file2.offer(source.poll());
|
||||
}
|
||||
}
|
||||
|
||||
// Méthode pour fusionner deux files triées en une seule file triée
|
||||
private static <T extends Comparable<T>> Queue<T> fusionner(Queue<T> file1, Queue<T> file2) {
|
||||
Queue<T> resultat = new ArrayQueue<>();
|
||||
|
||||
while (!file1.isEmpty() && !file2.isEmpty()) {
|
||||
if (file1.peek().compareTo(file2.peek()) <= 0) {
|
||||
resultat.offer(file1.poll());
|
||||
} else {
|
||||
resultat.offer(file2.poll());
|
||||
}
|
||||
}
|
||||
|
||||
// Ajouter les éléments restants de chaque file, s'il en reste
|
||||
while (!file1.isEmpty()) {
|
||||
resultat.offer(file1.poll());
|
||||
}
|
||||
while (!file2.isEmpty()) {
|
||||
resultat.offer(file2.poll());
|
||||
}
|
||||
|
||||
return resultat;
|
||||
}
|
||||
|
||||
// Méthode de test pour le tri
|
||||
public static void main(String[] args) {
|
||||
Queue<Double> file = new ArrayQueue<>();
|
||||
|
||||
// Remplir la file avec les arguments passés en ligne de commande
|
||||
for (String arg : args) {
|
||||
file.offer(Double.parseDouble(arg));
|
||||
}
|
||||
|
||||
// Tri de la file
|
||||
Queue<Double> fileTriee = trier(file);
|
||||
|
||||
// Affichage des éléments triés
|
||||
for (Double valeur : fileTriee) {
|
||||
System.out.print(valeur + " ");
|
||||
}
|
||||
System.out.println("");
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user