file mais dernier marche pas
This commit is contained in:
BIN
DEV3.2/Files/chaine/Arithmetique.class
Normal file
BIN
DEV3.2/Files/chaine/Arithmetique.class
Normal file
Binary file not shown.
58
DEV3.2/Files/chaine/Arithmetique.java
Normal file
58
DEV3.2/Files/chaine/Arithmetique.java
Normal file
@@ -0,0 +1,58 @@
|
||||
import java.util.Queue;
|
||||
|
||||
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 notre implémentation FileChainee pour la file
|
||||
Queue<Integer> queue = new FileChainee<>();
|
||||
|
||||
try {
|
||||
for (String token : args) {
|
||||
switch (token) {
|
||||
case "+":
|
||||
// Addition
|
||||
queue.offer(queue.poll() + queue.poll());
|
||||
break;
|
||||
case "-":
|
||||
// Soustraction (attention à l'ordre)
|
||||
int b = queue.poll();
|
||||
int a = queue.poll();
|
||||
queue.offer(a - b);
|
||||
break;
|
||||
case "x":
|
||||
// Multiplication
|
||||
queue.offer(queue.poll() * queue.poll());
|
||||
break;
|
||||
case "/":
|
||||
// Division (attention à l'ordre)
|
||||
b = queue.poll();
|
||||
a = queue.poll();
|
||||
if (b == 0) {
|
||||
throw new ArithmeticException("Division par zéro");
|
||||
}
|
||||
queue.offer(a / b);
|
||||
break;
|
||||
default:
|
||||
// Si ce n'est pas un opérateur, alors c'est un nombre
|
||||
queue.offer(Integer.parseInt(token));
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// Le résultat final doit être le seul élément restant dans la file
|
||||
if (queue.size() == 1) {
|
||||
System.out.println("= " + queue.poll());
|
||||
} 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/chaine/FileChainee$1.class
Normal file
BIN
DEV3.2/Files/chaine/FileChainee$1.class
Normal file
Binary file not shown.
BIN
DEV3.2/Files/chaine/FileChainee$Node.class
Normal file
BIN
DEV3.2/Files/chaine/FileChainee$Node.class
Normal file
Binary file not shown.
BIN
DEV3.2/Files/chaine/FileChainee.class
Normal file
BIN
DEV3.2/Files/chaine/FileChainee.class
Normal file
Binary file not shown.
78
DEV3.2/Files/chaine/FileChainee.java
Normal file
78
DEV3.2/Files/chaine/FileChainee.java
Normal file
@@ -0,0 +1,78 @@
|
||||
import java.util.AbstractQueue;
|
||||
import java.util.Iterator;
|
||||
import java.util.NoSuchElementException;
|
||||
import java.util.Queue;
|
||||
|
||||
public class FileChainee<E> extends AbstractQueue<E> implements Queue<E> {
|
||||
private static class Node<E> {
|
||||
E data;
|
||||
Node<E> next;
|
||||
|
||||
Node(E data) {
|
||||
this.data = data;
|
||||
}
|
||||
}
|
||||
|
||||
private Node<E> head; // Premier élément de la file
|
||||
private Node<E> tail; // Dernier élément de la file
|
||||
private int size = 0; // Taille de la file
|
||||
|
||||
@Override
|
||||
public boolean offer(E element) {
|
||||
Node<E> newNode = new Node<>(element);
|
||||
if (head == null) {
|
||||
tail = newNode;
|
||||
} else {
|
||||
newNode.next = head;
|
||||
}
|
||||
head = newNode;
|
||||
size++;
|
||||
return true;
|
||||
}
|
||||
|
||||
@Override
|
||||
public E poll() {
|
||||
if (isEmpty()) {
|
||||
return null;
|
||||
}
|
||||
E data = head.data;
|
||||
head = head.next;
|
||||
if (head == null) {
|
||||
tail = null;
|
||||
}
|
||||
size--;
|
||||
return data;
|
||||
}
|
||||
|
||||
@Override
|
||||
public E peek() {
|
||||
return (head == null) ? null : head.data;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Iterator<E> iterator() {
|
||||
return new Iterator<>() {
|
||||
private Node<E> current = head;
|
||||
|
||||
@Override
|
||||
public boolean hasNext() {
|
||||
return current != null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public E next() {
|
||||
if (!hasNext()) {
|
||||
throw new NoSuchElementException();
|
||||
}
|
||||
E data = current.data;
|
||||
current = current.next;
|
||||
return data;
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
@Override
|
||||
public int size() {
|
||||
return size;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user