Upload files to "java/expression"

This commit is contained in:
2026-04-13 10:50:54 +03:00
parent d6e1e5893f
commit a373740014
5 changed files with 209 additions and 0 deletions

44
java/expression/Max.java Normal file
View File

@@ -0,0 +1,44 @@
package expression;
import java.math.BigDecimal;
import java.math.BigInteger;
/**
* @author Doschennikov Nikita (me@fymio.us)
*/
public class Max extends AbstractBinaryOperation {
public Max(AbstractExpression l, AbstractExpression r) {
super(l, r);
}
@Override
protected String getOperator() {
return "max";
}
@Override
protected int getPriority() {
return 0;
}
@Override
protected boolean isRightAssoc() {
return false;
}
@Override
protected int applyInt(int a, int b) {
return Math.max(a, b);
}
@Override
protected BigInteger applyBi(BigInteger a, BigInteger b) {
return a.max(b);
}
@Override
protected BigDecimal applyBd(BigDecimal a, BigDecimal b) {
return a.max(b);
}
}

44
java/expression/Min.java Normal file
View File

@@ -0,0 +1,44 @@
package expression;
import java.math.BigDecimal;
import java.math.BigInteger;
/**
* @author Doschennikov Nikita (me@fymio.us)
*/
public class Min extends AbstractBinaryOperation {
public Min(AbstractExpression l, AbstractExpression r) {
super(l, r);
}
@Override
protected String getOperator() {
return "min";
}
@Override
protected int getPriority() {
return 0;
}
@Override
protected boolean isRightAssoc() {
return false;
}
@Override
protected int applyInt(int a, int b) {
return Math.min(a, b);
}
@Override
protected BigInteger applyBi(BigInteger a, BigInteger b) {
return a.min(b);
}
@Override
protected BigDecimal applyBd(BigDecimal a, BigDecimal b) {
return a.min(b);
}
}

View File

@@ -0,0 +1,44 @@
package expression;
import java.math.BigDecimal;
import java.math.BigInteger;
/**
* @author Doschennikov Nikita (me@fymio.us)
*/
public class Multiply extends AbstractBinaryOperation {
public Multiply(AbstractExpression l, AbstractExpression r) {
super(l, r);
}
@Override
protected String getOperator() {
return "*";
}
@Override
protected int getPriority() {
return 2;
}
@Override
protected boolean isRightAssoc() {
return false;
}
@Override
protected int applyInt(int a, int b) {
return a * b;
}
@Override
protected BigInteger applyBi(BigInteger a, BigInteger b) {
return a.multiply(b);
}
@Override
protected BigDecimal applyBd(BigDecimal a, BigDecimal b) {
return a.multiply(b);
}
}

View File

@@ -0,0 +1,67 @@
package expression;
import java.math.BigDecimal;
import java.math.BigInteger;
import java.util.List;
/**
* @author Doschennikov Nikita (me@fymio.us)
*/
public class Negate extends AbstractExpression {
private final AbstractExpression operand;
public Negate(AbstractExpression operand) {
this.operand = operand;
}
@Override
public int evaluate(int x) {
return -operand.evaluate(x);
}
@Override
public int evaluate(int x, int y, int z) {
return -operand.evaluate(x, y, z);
}
@Override
public int evaluate(List<Integer> vars) {
return -operand.evaluate(vars);
}
@Override
public BigInteger evaluateBi(List<BigInteger> vars) {
return operand.evaluateBi(vars).negate();
}
@Override
public BigDecimal evaluateBd(List<BigDecimal> vars) {
return operand.evaluateBd(vars).negate();
}
@Override
public String toString() {
return "-(" + operand + ")";
}
@Override
public String toMiniString() {
if (operand instanceof AbstractBinaryOperation) {
return "-(" + operand.toMiniString() + ")";
}
return "- " + operand.toMiniString();
}
@Override
public boolean equals(Object obj) {
if (this == obj) return true;
if (!(obj instanceof Negate)) return false;
return operand.equals(((Negate) obj).operand);
}
@Override
public int hashCode() {
return -operand.hashCode();
}
}

View File

@@ -0,0 +1,10 @@
package expression;
/**
* @author Doschennikov Nikita (me@fymio.us)
*/
public class OverflowException extends ArithmeticException {
public OverflowException(String operation) {
super("overflow in " + operation);
}
}