Merge pull request #12305 from keerthigadde/JAVA-12099/move-java-numbers

JAVA-12099 moved java-numbers modules to core-java-modules
This commit is contained in:
kwoyke 2022-06-08 08:18:58 +02:00 committed by GitHub
commit fa6f3420d5
101 changed files with 741 additions and 749 deletions

View File

@ -9,10 +9,9 @@
<packaging>jar</packaging> <packaging>jar</packaging>
<parent> <parent>
<groupId>com.baeldung</groupId> <groupId>com.baeldung.core-java-modules</groupId>
<artifactId>parent-java</artifactId> <artifactId>core-java-modules</artifactId>
<version>0.0.1-SNAPSHOT</version> <version>0.0.1-SNAPSHOT</version>
<relativePath>../parent-java</relativePath>
</parent> </parent>
<dependencies> <dependencies>

View File

@ -1,140 +1,140 @@
package com.baeldung.binarynumbers; package com.baeldung.binarynumbers;
public class BinaryNumbers { public class BinaryNumbers {
/** /**
* This method takes a decimal number and convert it into a binary number. * This method takes a decimal number and convert it into a binary number.
* example:- input:10, output:1010 * example:- input:10, output:1010
* *
* @param decimalNumber * @param decimalNumber
* @return binary number * @return binary number
*/ */
public Integer convertDecimalToBinary(Integer decimalNumber) { public Integer convertDecimalToBinary(Integer decimalNumber) {
if (decimalNumber == 0) { if (decimalNumber == 0) {
return decimalNumber; return decimalNumber;
} }
StringBuilder binaryNumber = new StringBuilder(); StringBuilder binaryNumber = new StringBuilder();
Integer quotient = decimalNumber; Integer quotient = decimalNumber;
while (quotient > 0) { while (quotient > 0) {
int remainder = quotient % 2; int remainder = quotient % 2;
binaryNumber.append(remainder); binaryNumber.append(remainder);
quotient /= 2; quotient /= 2;
} }
binaryNumber = binaryNumber.reverse(); binaryNumber = binaryNumber.reverse();
return Integer.valueOf(binaryNumber.toString()); return Integer.valueOf(binaryNumber.toString());
} }
/** /**
* This method takes a binary number and convert it into a decimal number. * This method takes a binary number and convert it into a decimal number.
* example:- input:101, output:5 * example:- input:101, output:5
* *
* @param binary number * @param binary number
* @return decimal Number * @return decimal Number
*/ */
public Integer convertBinaryToDecimal(Integer binaryNumber) { public Integer convertBinaryToDecimal(Integer binaryNumber) {
Integer decimalNumber = 0; Integer decimalNumber = 0;
Integer base = 1; Integer base = 1;
while (binaryNumber > 0) { while (binaryNumber > 0) {
int lastDigit = binaryNumber % 10; int lastDigit = binaryNumber % 10;
binaryNumber = binaryNumber / 10; binaryNumber = binaryNumber / 10;
decimalNumber += lastDigit * base; decimalNumber += lastDigit * base;
base = base * 2; base = base * 2;
} }
return decimalNumber; return decimalNumber;
} }
/** /**
* This method accepts two binary numbers and returns sum of input numbers. * This method accepts two binary numbers and returns sum of input numbers.
* Example:- firstNum: 101, secondNum: 100, output: 1001 * Example:- firstNum: 101, secondNum: 100, output: 1001
* *
* @param firstNum * @param firstNum
* @param secondNum * @param secondNum
* @return addition of input numbers * @return addition of input numbers
*/ */
public Integer addBinaryNumber(Integer firstNum, Integer secondNum) { public Integer addBinaryNumber(Integer firstNum, Integer secondNum) {
StringBuilder output = new StringBuilder(); StringBuilder output = new StringBuilder();
int carry = 0; int carry = 0;
int temp; int temp;
while (firstNum != 0 || secondNum != 0) { while (firstNum != 0 || secondNum != 0) {
temp = (firstNum % 10 + secondNum % 10 + carry) % 2; temp = (firstNum % 10 + secondNum % 10 + carry) % 2;
output.append(temp); output.append(temp);
carry = (firstNum % 10 + secondNum % 10 + carry) / 2; carry = (firstNum % 10 + secondNum % 10 + carry) / 2;
firstNum = firstNum / 10; firstNum = firstNum / 10;
secondNum = secondNum / 10; secondNum = secondNum / 10;
} }
if (carry != 0) { if (carry != 0) {
output.append(carry); output.append(carry);
} }
return Integer.valueOf(output.reverse() return Integer.valueOf(output.reverse()
.toString()); .toString());
} }
/** /**
* This method takes two binary number as input and subtract second number from the first number. * This method takes two binary number as input and subtract second number from the first number.
* example:- firstNum: 1000, secondNum: 11, output: 101 * example:- firstNum: 1000, secondNum: 11, output: 101
* @param firstNum * @param firstNum
* @param secondNum * @param secondNum
* @return Result of subtraction of secondNum from first * @return Result of subtraction of secondNum from first
*/ */
public Integer substractBinaryNumber(Integer firstNum, Integer secondNum) { public Integer substractBinaryNumber(Integer firstNum, Integer secondNum) {
int onesComplement = Integer.valueOf(getOnesComplement(secondNum)); int onesComplement = Integer.valueOf(getOnesComplement(secondNum));
StringBuilder output = new StringBuilder(); StringBuilder output = new StringBuilder();
int carry = 0; int carry = 0;
int temp; int temp;
while (firstNum != 0 || onesComplement != 0) { while (firstNum != 0 || onesComplement != 0) {
temp = (firstNum % 10 + onesComplement % 10 + carry) % 2; temp = (firstNum % 10 + onesComplement % 10 + carry) % 2;
output.append(temp); output.append(temp);
carry = (firstNum % 10 + onesComplement % 10 + carry) / 2; carry = (firstNum % 10 + onesComplement % 10 + carry) / 2;
firstNum = firstNum / 10; firstNum = firstNum / 10;
onesComplement = onesComplement / 10; onesComplement = onesComplement / 10;
} }
String additionOfFirstNumAndOnesComplement = output.reverse() String additionOfFirstNumAndOnesComplement = output.reverse()
.toString(); .toString();
if (carry == 1) { if (carry == 1) {
return addBinaryNumber(Integer.valueOf(additionOfFirstNumAndOnesComplement), carry); return addBinaryNumber(Integer.valueOf(additionOfFirstNumAndOnesComplement), carry);
} else { } else {
return getOnesComplement(Integer.valueOf(additionOfFirstNumAndOnesComplement)); return getOnesComplement(Integer.valueOf(additionOfFirstNumAndOnesComplement));
} }
} }
public Integer getOnesComplement(Integer num) { public Integer getOnesComplement(Integer num) {
StringBuilder onesComplement = new StringBuilder(); StringBuilder onesComplement = new StringBuilder();
while (num > 0) { while (num > 0) {
int lastDigit = num % 10; int lastDigit = num % 10;
if (lastDigit == 0) { if (lastDigit == 0) {
onesComplement.append(1); onesComplement.append(1);
} else { } else {
onesComplement.append(0); onesComplement.append(0);
} }
num = num / 10; num = num / 10;
} }
return Integer.valueOf(onesComplement.reverse() return Integer.valueOf(onesComplement.reverse()
.toString()); .toString());
} }
} }

View File

@ -1,73 +1,73 @@
package com.baeldung.binarynumbers; package com.baeldung.binarynumbers;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import org.junit.Test; import org.junit.Test;
public class BinaryNumbersUnitTest { public class BinaryNumbersUnitTest {
private BinaryNumbers binaryNumbers = new BinaryNumbers(); private BinaryNumbers binaryNumbers = new BinaryNumbers();
@Test @Test
public void given_decimalNumber_then_returnBinaryNumber() { public void given_decimalNumber_then_returnBinaryNumber() {
assertEquals(Integer.valueOf(1000), binaryNumbers.convertDecimalToBinary(8)); assertEquals(Integer.valueOf(1000), binaryNumbers.convertDecimalToBinary(8));
assertEquals(Integer.valueOf(10100), binaryNumbers.convertDecimalToBinary(20)); assertEquals(Integer.valueOf(10100), binaryNumbers.convertDecimalToBinary(20));
} }
@Test @Test
public void given_decimalNumber_then_convertToBinaryNumber() { public void given_decimalNumber_then_convertToBinaryNumber() {
assertEquals("1000", Integer.toBinaryString(8)); assertEquals("1000", Integer.toBinaryString(8));
assertEquals("10100", Integer.toBinaryString(20)); assertEquals("10100", Integer.toBinaryString(20));
} }
@Test @Test
public void given_binaryNumber_then_ConvertToDecimalNumber() { public void given_binaryNumber_then_ConvertToDecimalNumber() {
assertEquals(8, Integer.parseInt("1000", 2)); assertEquals(8, Integer.parseInt("1000", 2));
assertEquals(20, Integer.parseInt("10100", 2)); assertEquals(20, Integer.parseInt("10100", 2));
} }
@Test @Test
public void given_binaryNumber_then_returnDecimalNumber() { public void given_binaryNumber_then_returnDecimalNumber() {
assertEquals(Integer.valueOf(8), binaryNumbers.convertBinaryToDecimal(1000)); assertEquals(Integer.valueOf(8), binaryNumbers.convertBinaryToDecimal(1000));
assertEquals(Integer.valueOf(20), binaryNumbers.convertBinaryToDecimal(10100)); assertEquals(Integer.valueOf(20), binaryNumbers.convertBinaryToDecimal(10100));
} }
@Test @Test
public void given_twoBinaryNumber_then_returnAddition() { public void given_twoBinaryNumber_then_returnAddition() {
// adding 4 and 10 // adding 4 and 10
assertEquals(Integer.valueOf(1110), binaryNumbers.addBinaryNumber(100, 1010)); assertEquals(Integer.valueOf(1110), binaryNumbers.addBinaryNumber(100, 1010));
// adding 26 and 14 // adding 26 and 14
assertEquals(Integer.valueOf(101000), binaryNumbers.addBinaryNumber(11010, 1110)); assertEquals(Integer.valueOf(101000), binaryNumbers.addBinaryNumber(11010, 1110));
} }
@Test @Test
public void given_twoBinaryNumber_then_returnSubtraction() { public void given_twoBinaryNumber_then_returnSubtraction() {
// subtracting 16 from 25 // subtracting 16 from 25
assertEquals(Integer.valueOf(1001), binaryNumbers.substractBinaryNumber(11001, 10000)); assertEquals(Integer.valueOf(1001), binaryNumbers.substractBinaryNumber(11001, 10000));
// subtracting 29 from 16, the output here is negative // subtracting 29 from 16, the output here is negative
assertEquals(Integer.valueOf(1101), binaryNumbers.substractBinaryNumber(10000, 11101)); assertEquals(Integer.valueOf(1101), binaryNumbers.substractBinaryNumber(10000, 11101));
} }
@Test @Test
public void given_binaryLiteral_thenReturnDecimalValue() { public void given_binaryLiteral_thenReturnDecimalValue() {
byte five = 0b101; byte five = 0b101;
assertEquals((byte) 5, five); assertEquals((byte) 5, five);
short three = 0b11; short three = 0b11;
assertEquals((short) 3, three); assertEquals((short) 3, three);
int nine = 0B1001; int nine = 0B1001;
assertEquals(9, nine); assertEquals(9, nine);
long twentyNine = 0B11101; long twentyNine = 0B11101;
assertEquals(29, twentyNine); assertEquals(29, twentyNine);
int minusThirtySeven = -0B100101; int minusThirtySeven = -0B100101;
assertEquals(-37, minusThirtySeven); assertEquals(-37, minusThirtySeven);
} }
} }

View File

@ -7,10 +7,9 @@
<packaging>jar</packaging> <packaging>jar</packaging>
<parent> <parent>
<groupId>com.baeldung</groupId> <groupId>com.baeldung.core-java-modules</groupId>
<artifactId>parent-java</artifactId> <artifactId>core-java-modules</artifactId>
<version>0.0.1-SNAPSHOT</version> <version>0.0.1-SNAPSHOT</version>
<relativePath>../parent-java</relativePath>
</parent> </parent>
<dependencies> <dependencies>

View File

@ -7,10 +7,9 @@
<packaging>jar</packaging> <packaging>jar</packaging>
<parent> <parent>
<groupId>com.baeldung</groupId> <groupId>com.baeldung.core-java-modules</groupId>
<artifactId>parent-java</artifactId> <artifactId>core-java-modules</artifactId>
<version>0.0.1-SNAPSHOT</version> <version>0.0.1-SNAPSHOT</version>
<relativePath>../parent-java</relativePath>
</parent> </parent>
<dependencies> <dependencies>

View File

@ -9,10 +9,9 @@
<packaging>jar</packaging> <packaging>jar</packaging>
<parent> <parent>
<groupId>com.baeldung</groupId> <groupId>com.baeldung.core-java-modules</groupId>
<artifactId>parent-java</artifactId> <artifactId>core-java-modules</artifactId>
<version>0.0.1-SNAPSHOT</version> <version>0.0.1-SNAPSHOT</version>
<relativePath>../parent-java</relativePath>
</parent> </parent>
<dependencies> <dependencies>

View File

@ -1,51 +1,51 @@
package com.baeldung.maths; package com.baeldung.maths;
import java.math.BigDecimal; import java.math.BigDecimal;
public class FloatingPointArithmetic { public class FloatingPointArithmetic {
public static void main(String[] args) { public static void main(String[] args) {
double a = 13.22; double a = 13.22;
double b = 4.88; double b = 4.88;
double c = 21.45; double c = 21.45;
System.out.println("a = " + a); System.out.println("a = " + a);
System.out.println("b = " + b); System.out.println("b = " + b);
System.out.println("c = " + c); System.out.println("c = " + c);
double sum_ab = a + b; double sum_ab = a + b;
System.out.println("a + b = " + sum_ab); System.out.println("a + b = " + sum_ab);
double abc = a + b + c; double abc = a + b + c;
System.out.println("a + b + c = " + abc); System.out.println("a + b + c = " + abc);
double ab_c = sum_ab + c; double ab_c = sum_ab + c;
System.out.println("ab + c = " + ab_c); System.out.println("ab + c = " + ab_c);
double sum_ac = a + c; double sum_ac = a + c;
System.out.println("a + c = " + sum_ac); System.out.println("a + c = " + sum_ac);
double acb = a + c + b; double acb = a + c + b;
System.out.println("a + c + b = " + acb); System.out.println("a + c + b = " + acb);
double ac_b = sum_ac + b; double ac_b = sum_ac + b;
System.out.println("ac + b = " + ac_b); System.out.println("ac + b = " + ac_b);
double ab = 18.1; double ab = 18.1;
double ac = 34.67; double ac = 34.67;
double sum_ab_c = ab + c; double sum_ab_c = ab + c;
double sum_ac_b = ac + b; double sum_ac_b = ac + b;
System.out.println("ab + c = " + sum_ab_c); System.out.println("ab + c = " + sum_ab_c);
System.out.println("ac + b = " + sum_ac_b); System.out.println("ac + b = " + sum_ac_b);
BigDecimal d = new BigDecimal(String.valueOf(a)); BigDecimal d = new BigDecimal(String.valueOf(a));
BigDecimal e = new BigDecimal(String.valueOf(b)); BigDecimal e = new BigDecimal(String.valueOf(b));
BigDecimal f = new BigDecimal(String.valueOf(c)); BigDecimal f = new BigDecimal(String.valueOf(c));
BigDecimal def = d.add(e).add(f); BigDecimal def = d.add(e).add(f);
BigDecimal dfe = d.add(f).add(e); BigDecimal dfe = d.add(f).add(e);
System.out.println("d + e + f = " + def); System.out.println("d + e + f = " + def);
System.out.println("d + f + e = " + dfe); System.out.println("d + f + e = " + dfe);
} }
} }

View File

@ -1,67 +1,67 @@
package com.baeldung.numberofdigits; package com.baeldung.numberofdigits;
import java.io.IOException; import java.io.IOException;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
import org.openjdk.jmh.annotations.Benchmark; import org.openjdk.jmh.annotations.Benchmark;
import org.openjdk.jmh.annotations.BenchmarkMode; import org.openjdk.jmh.annotations.BenchmarkMode;
import org.openjdk.jmh.annotations.Mode; import org.openjdk.jmh.annotations.Mode;
import org.openjdk.jmh.annotations.OutputTimeUnit; import org.openjdk.jmh.annotations.OutputTimeUnit;
import org.openjdk.jmh.annotations.Scope; import org.openjdk.jmh.annotations.Scope;
import org.openjdk.jmh.annotations.State; import org.openjdk.jmh.annotations.State;
import org.openjdk.jmh.runner.RunnerException; import org.openjdk.jmh.runner.RunnerException;
public class Benchmarking { public class Benchmarking {
public static void main(String[] args) throws RunnerException, IOException { public static void main(String[] args) throws RunnerException, IOException {
org.openjdk.jmh.Main.main(args); org.openjdk.jmh.Main.main(args);
} }
@State(Scope.Thread) @State(Scope.Thread)
public static class ExecutionPlan { public static class ExecutionPlan {
public int number = Integer.MAX_VALUE; public int number = Integer.MAX_VALUE;
public int length = 0; public int length = 0;
public NumberOfDigits numberOfDigits= new NumberOfDigits(); public NumberOfDigits numberOfDigits= new NumberOfDigits();
} }
@Benchmark @Benchmark
@BenchmarkMode(Mode.AverageTime) @BenchmarkMode(Mode.AverageTime)
@OutputTimeUnit(TimeUnit.NANOSECONDS) @OutputTimeUnit(TimeUnit.NANOSECONDS)
public void stringBasedSolution(ExecutionPlan plan) { public void stringBasedSolution(ExecutionPlan plan) {
plan.length = plan.numberOfDigits.stringBasedSolution(plan.number); plan.length = plan.numberOfDigits.stringBasedSolution(plan.number);
} }
@Benchmark @Benchmark
@BenchmarkMode(Mode.AverageTime) @BenchmarkMode(Mode.AverageTime)
@OutputTimeUnit(TimeUnit.NANOSECONDS) @OutputTimeUnit(TimeUnit.NANOSECONDS)
public void logarithmicApproach(ExecutionPlan plan) { public void logarithmicApproach(ExecutionPlan plan) {
plan.length = plan.numberOfDigits.logarithmicApproach(plan.number); plan.length = plan.numberOfDigits.logarithmicApproach(plan.number);
} }
@Benchmark @Benchmark
@BenchmarkMode(Mode.AverageTime) @BenchmarkMode(Mode.AverageTime)
@OutputTimeUnit(TimeUnit.NANOSECONDS) @OutputTimeUnit(TimeUnit.NANOSECONDS)
public void repeatedMultiplication(ExecutionPlan plan) { public void repeatedMultiplication(ExecutionPlan plan) {
plan.length = plan.numberOfDigits.repeatedMultiplication(plan.number); plan.length = plan.numberOfDigits.repeatedMultiplication(plan.number);
} }
@Benchmark @Benchmark
@BenchmarkMode(Mode.AverageTime) @BenchmarkMode(Mode.AverageTime)
@OutputTimeUnit(TimeUnit.NANOSECONDS) @OutputTimeUnit(TimeUnit.NANOSECONDS)
public void shiftOperators(ExecutionPlan plan) { public void shiftOperators(ExecutionPlan plan) {
plan.length = plan.numberOfDigits.shiftOperators(plan.number); plan.length = plan.numberOfDigits.shiftOperators(plan.number);
} }
@Benchmark @Benchmark
@BenchmarkMode(Mode.AverageTime) @BenchmarkMode(Mode.AverageTime)
@OutputTimeUnit(TimeUnit.NANOSECONDS) @OutputTimeUnit(TimeUnit.NANOSECONDS)
public void dividingWithPowersOf2(ExecutionPlan plan) { public void dividingWithPowersOf2(ExecutionPlan plan) {
plan.length = plan.numberOfDigits.dividingWithPowersOf2(plan.number); plan.length = plan.numberOfDigits.dividingWithPowersOf2(plan.number);
} }
@Benchmark @Benchmark
@BenchmarkMode(Mode.AverageTime) @BenchmarkMode(Mode.AverageTime)
@OutputTimeUnit(TimeUnit.NANOSECONDS) @OutputTimeUnit(TimeUnit.NANOSECONDS)
public void divideAndConquer(ExecutionPlan plan) { public void divideAndConquer(ExecutionPlan plan) {
plan.length = plan.numberOfDigits.divideAndConquer(plan.number); plan.length = plan.numberOfDigits.divideAndConquer(plan.number);
} }
} }

View File

@ -1,97 +1,97 @@
package com.baeldung.numberofdigits; package com.baeldung.numberofdigits;
public class NumberOfDigits { public class NumberOfDigits {
public int stringBasedSolution(int number) { public int stringBasedSolution(int number) {
int length = String.valueOf(number).length(); int length = String.valueOf(number).length();
return length; return length;
} }
public int logarithmicApproach(int number) { public int logarithmicApproach(int number) {
int length = (int) Math.log10(number) + 1; int length = (int) Math.log10(number) + 1;
return length; return length;
} }
public int repeatedMultiplication(int number) { public int repeatedMultiplication(int number) {
int length = 0; int length = 0;
long temp = 1; long temp = 1;
while(temp <= number) { while(temp <= number) {
length++; length++;
temp *= 10; temp *= 10;
} }
return length; return length;
} }
public int shiftOperators(int number) { public int shiftOperators(int number) {
int length = 0; int length = 0;
long temp = 1; long temp = 1;
while(temp <= number) { while(temp <= number) {
length++; length++;
temp = (temp << 3) + (temp << 1); temp = (temp << 3) + (temp << 1);
} }
return length; return length;
} }
public int dividingWithPowersOf2(int number) { public int dividingWithPowersOf2(int number) {
int length = 1; int length = 1;
if (number >= 100000000) { if (number >= 100000000) {
length += 8; length += 8;
number /= 100000000; number /= 100000000;
} }
if (number >= 10000) { if (number >= 10000) {
length += 4; length += 4;
number /= 10000; number /= 10000;
} }
if (number >= 100) { if (number >= 100) {
length += 2; length += 2;
number /= 100; number /= 100;
} }
if (number >= 10) { if (number >= 10) {
length += 1; length += 1;
} }
return length; return length;
} }
public int divideAndConquer(int number) { public int divideAndConquer(int number) {
if (number < 100000){ if (number < 100000){
// 5 digits or less // 5 digits or less
if (number < 100){ if (number < 100){
// 1 or 2 // 1 or 2
if (number < 10) if (number < 10)
return 1; return 1;
else else
return 2; return 2;
}else{ }else{
// 3 to 5 digits // 3 to 5 digits
if (number < 1000) if (number < 1000)
return 3; return 3;
else{ else{
// 4 or 5 digits // 4 or 5 digits
if (number < 10000) if (number < 10000)
return 4; return 4;
else else
return 5; return 5;
} }
} }
} else { } else {
// 6 digits or more // 6 digits or more
if (number < 10000000) { if (number < 10000000) {
// 6 or 7 digits // 6 or 7 digits
if (number < 1000000) if (number < 1000000)
return 6; return 6;
else else
return 7; return 7;
} else { } else {
// 8 to 10 digits // 8 to 10 digits
if (number < 100000000) if (number < 100000000)
return 8; return 8;
else { else {
// 9 or 10 digits // 9 or 10 digits
if (number < 1000000000) if (number < 1000000000)
return 9; return 9;
else else
return 10; return 10;
} }
} }
} }
} }
} }

View File

@ -1,35 +1,35 @@
package com.baeldung.numberofdigits; package com.baeldung.numberofdigits;
import org.apache.log4j.Logger; import org.apache.log4j.Logger;
public class NumberOfDigitsDriver { public class NumberOfDigitsDriver {
private static NumberOfDigits numberOfDigits; private static NumberOfDigits numberOfDigits;
private static Logger LOG = Logger.getLogger(NumberOfDigitsDriver.class); private static Logger LOG = Logger.getLogger(NumberOfDigitsDriver.class);
static { static {
numberOfDigits = new NumberOfDigits(); numberOfDigits = new NumberOfDigits();
} }
public static void main(String[] args) { public static void main(String[] args) {
LOG.info("Testing all methods..."); LOG.info("Testing all methods...");
long length = numberOfDigits.stringBasedSolution(602); long length = numberOfDigits.stringBasedSolution(602);
LOG.info("String Based Solution : " + length); LOG.info("String Based Solution : " + length);
length = numberOfDigits.logarithmicApproach(602); length = numberOfDigits.logarithmicApproach(602);
LOG.info("Logarithmic Approach : " + length); LOG.info("Logarithmic Approach : " + length);
length = numberOfDigits.repeatedMultiplication(602); length = numberOfDigits.repeatedMultiplication(602);
LOG.info("Repeated Multiplication : " + length); LOG.info("Repeated Multiplication : " + length);
length = numberOfDigits.shiftOperators(602); length = numberOfDigits.shiftOperators(602);
LOG.info("Shift Operators : " + length); LOG.info("Shift Operators : " + length);
length = numberOfDigits.dividingWithPowersOf2(602); length = numberOfDigits.dividingWithPowersOf2(602);
LOG.info("Dividing with Powers of 2 : " + length); LOG.info("Dividing with Powers of 2 : " + length);
length = numberOfDigits.divideAndConquer(602); length = numberOfDigits.divideAndConquer(602);
LOG.info("Divide And Conquer : " + length); LOG.info("Divide And Conquer : " + length);
} }
} }

View File

@ -1,25 +1,25 @@
package com.baeldung.maths; package com.baeldung.maths;
import org.junit.Assert; import org.junit.Assert;
import org.junit.Test; import org.junit.Test;
import java.math.BigDecimal; import java.math.BigDecimal;
import java.math.RoundingMode; import java.math.RoundingMode;
public class BigDecimalImplUnitTest { public class BigDecimalImplUnitTest {
@Test @Test
public void givenBigDecimalNumbers_whenAddedTogether_thenGetExpectedResult() { public void givenBigDecimalNumbers_whenAddedTogether_thenGetExpectedResult() {
BigDecimal serviceTax = new BigDecimal("56.0084578639"); BigDecimal serviceTax = new BigDecimal("56.0084578639");
serviceTax = serviceTax.setScale(2, RoundingMode.CEILING); serviceTax = serviceTax.setScale(2, RoundingMode.CEILING);
BigDecimal entertainmentTax = new BigDecimal("23.00689"); BigDecimal entertainmentTax = new BigDecimal("23.00689");
entertainmentTax = entertainmentTax.setScale(2, RoundingMode.FLOOR); entertainmentTax = entertainmentTax.setScale(2, RoundingMode.FLOOR);
BigDecimal totalTax = serviceTax.add(entertainmentTax); BigDecimal totalTax = serviceTax.add(entertainmentTax);
BigDecimal result = BigDecimal.valueOf(79.01); BigDecimal result = BigDecimal.valueOf(79.01);
Assert.assertEquals(result, totalTax); Assert.assertEquals(result, totalTax);
} }
} }

View File

@ -1,21 +1,21 @@
package com.baeldung.maths; package com.baeldung.maths;
import org.junit.Assert; import org.junit.Assert;
import org.junit.Test; import org.junit.Test;
import java.math.BigInteger; import java.math.BigInteger;
public class BigIntegerImplUnitTest { public class BigIntegerImplUnitTest {
@Test @Test
public void givenBigIntegerNumbers_whenAddedTogether_thenGetExpectedResult() { public void givenBigIntegerNumbers_whenAddedTogether_thenGetExpectedResult() {
BigInteger numStarsMilkyWay = new BigInteger("8731409320171337804361260816606476"); BigInteger numStarsMilkyWay = new BigInteger("8731409320171337804361260816606476");
BigInteger numStarsAndromeda = new BigInteger("5379309320171337804361260816606476"); BigInteger numStarsAndromeda = new BigInteger("5379309320171337804361260816606476");
BigInteger totalStars = numStarsMilkyWay.add(numStarsAndromeda); BigInteger totalStars = numStarsMilkyWay.add(numStarsAndromeda);
BigInteger result = new BigInteger("14110718640342675608722521633212952"); BigInteger result = new BigInteger("14110718640342675608722521633212952");
Assert.assertEquals(result, totalStars); Assert.assertEquals(result, totalStars);
} }
} }

View File

@ -1,45 +1,45 @@
package com.baeldung.maths; package com.baeldung.maths;
import java.math.BigDecimal; import java.math.BigDecimal;
import org.junit.Assert; import org.junit.Assert;
import org.junit.Test; import org.junit.Test;
public class FloatingPointArithmeticUnitTest { public class FloatingPointArithmeticUnitTest {
@Test @Test
public void givenDecimalNumbers_whenAddedTogether_thenGetExpectedResult() { public void givenDecimalNumbers_whenAddedTogether_thenGetExpectedResult() {
double a = 13.22; double a = 13.22;
double b = 4.88; double b = 4.88;
double c = 21.45; double c = 21.45;
double result = 39.55; double result = 39.55;
double abc = a + b + c; double abc = a + b + c;
double acb = a + c + b; double acb = a + c + b;
Assert.assertEquals(result, abc, 0); Assert.assertEquals(result, abc, 0);
Assert.assertNotEquals(result, acb, 0); Assert.assertNotEquals(result, acb, 0);
double ab = 18.1; double ab = 18.1;
double ac = 34.67; double ac = 34.67;
double ab_c = ab + c; double ab_c = ab + c;
double ac_b = ac + b; double ac_b = ac + b;
Assert.assertEquals(result, ab_c, 0); Assert.assertEquals(result, ab_c, 0);
Assert.assertNotEquals(result, ac_b, 0); Assert.assertNotEquals(result, ac_b, 0);
BigDecimal d = new BigDecimal(String.valueOf(a)); BigDecimal d = new BigDecimal(String.valueOf(a));
BigDecimal e = new BigDecimal(String.valueOf(b)); BigDecimal e = new BigDecimal(String.valueOf(b));
BigDecimal f = new BigDecimal(String.valueOf(c)); BigDecimal f = new BigDecimal(String.valueOf(c));
BigDecimal sum = new BigDecimal("39.55"); BigDecimal sum = new BigDecimal("39.55");
BigDecimal def = d.add(e).add(f); BigDecimal def = d.add(e).add(f);
BigDecimal dfe = d.add(f).add(e); BigDecimal dfe = d.add(f).add(e);
Assert.assertEquals(0, def.compareTo(sum)); Assert.assertEquals(0, def.compareTo(sum));
Assert.assertEquals(0, dfe.compareTo(sum)); Assert.assertEquals(0, dfe.compareTo(sum));
Assert.assertNotEquals(0, sum.compareTo(new BigDecimal(String.valueOf(acb)))); Assert.assertNotEquals(0, sum.compareTo(new BigDecimal(String.valueOf(acb))));
} }
} }

View File

@ -1,71 +1,71 @@
package com.baeldung.maths; package com.baeldung.maths;
import org.apache.commons.math3.util.Precision; import org.apache.commons.math3.util.Precision;
import org.decimal4j.util.DoubleRounder; import org.decimal4j.util.DoubleRounder;
import org.junit.Assert; import org.junit.Assert;
import org.junit.Test; import org.junit.Test;
public class RoundUnitTest { public class RoundUnitTest {
private double value = 2.03456d; private double value = 2.03456d;
private int places = 2; private int places = 2;
private double delta = 0.0d; private double delta = 0.0d;
private double expected = 2.03d; private double expected = 2.03d;
@Test @Test
public void givenDecimalNumber_whenRoundToNDecimalPlaces_thenGetExpectedResult() { public void givenDecimalNumber_whenRoundToNDecimalPlaces_thenGetExpectedResult() {
Assert.assertEquals(expected, Round.round(value, places), delta); Assert.assertEquals(expected, Round.round(value, places), delta);
Assert.assertEquals(expected, Round.roundNotPrecise(value, places), delta); Assert.assertEquals(expected, Round.roundNotPrecise(value, places), delta);
Assert.assertEquals(expected, Round.roundAvoid(value, places), delta); Assert.assertEquals(expected, Round.roundAvoid(value, places), delta);
Assert.assertEquals(expected, Precision.round(value, places), delta); Assert.assertEquals(expected, Precision.round(value, places), delta);
Assert.assertEquals(expected, DoubleRounder.round(value, places), delta); Assert.assertEquals(expected, DoubleRounder.round(value, places), delta);
places = 3; places = 3;
expected = 2.035d; expected = 2.035d;
Assert.assertEquals(expected, Round.round(value, places), delta); Assert.assertEquals(expected, Round.round(value, places), delta);
Assert.assertEquals(expected, Round.roundNotPrecise(value, places), delta); Assert.assertEquals(expected, Round.roundNotPrecise(value, places), delta);
Assert.assertEquals(expected, Round.roundAvoid(value, places), delta); Assert.assertEquals(expected, Round.roundAvoid(value, places), delta);
Assert.assertEquals(expected, Precision.round(value, places), delta); Assert.assertEquals(expected, Precision.round(value, places), delta);
Assert.assertEquals(expected, DoubleRounder.round(value, places), delta); Assert.assertEquals(expected, DoubleRounder.round(value, places), delta);
value = 1000.0d; value = 1000.0d;
places = 17; places = 17;
expected = 1000.0d; expected = 1000.0d;
Assert.assertEquals(expected, Round.round(value, places), delta); Assert.assertEquals(expected, Round.round(value, places), delta);
Assert.assertEquals(expected, Round.roundNotPrecise(value, places), delta); Assert.assertEquals(expected, Round.roundNotPrecise(value, places), delta);
Assert.assertNotEquals(expected, Round.roundAvoid(value, places), delta); // Returns: 92.23372036854776 ! Assert.assertNotEquals(expected, Round.roundAvoid(value, places), delta); // Returns: 92.23372036854776 !
Assert.assertEquals(expected, Precision.round(value, places), delta); Assert.assertEquals(expected, Precision.round(value, places), delta);
Assert.assertEquals(expected, DoubleRounder.round(value, places), delta); Assert.assertEquals(expected, DoubleRounder.round(value, places), delta);
value = 256.025d; value = 256.025d;
places = 2; places = 2;
expected = 256.03d; expected = 256.03d;
Assert.assertEquals(expected, Round.round(value, places), delta); Assert.assertEquals(expected, Round.round(value, places), delta);
Assert.assertNotEquals(expected, Round.roundNotPrecise(value, places), delta); // Returns: 256.02 ! Assert.assertNotEquals(expected, Round.roundNotPrecise(value, places), delta); // Returns: 256.02 !
Assert.assertNotEquals(expected, Round.roundAvoid(value, places), delta); // Returns: 256.02 ! Assert.assertNotEquals(expected, Round.roundAvoid(value, places), delta); // Returns: 256.02 !
Assert.assertEquals(expected, Precision.round(value, places), delta); Assert.assertEquals(expected, Precision.round(value, places), delta);
Assert.assertNotEquals(expected, DoubleRounder.round(value, places), delta); // Returns: 256.02 ! Assert.assertNotEquals(expected, DoubleRounder.round(value, places), delta); // Returns: 256.02 !
value = 260.775d; value = 260.775d;
places = 2; places = 2;
expected = 260.78d; expected = 260.78d;
Assert.assertEquals(expected, Round.round(value, places), delta); Assert.assertEquals(expected, Round.round(value, places), delta);
Assert.assertNotEquals(expected, Round.roundNotPrecise(value, places), delta); // Returns: 260.77 ! Assert.assertNotEquals(expected, Round.roundNotPrecise(value, places), delta); // Returns: 260.77 !
Assert.assertNotEquals(expected, Round.roundAvoid(value, places), delta); // Returns: 260.77 ! Assert.assertNotEquals(expected, Round.roundAvoid(value, places), delta); // Returns: 260.77 !
Assert.assertEquals(expected, Precision.round(value, places), delta); Assert.assertEquals(expected, Precision.round(value, places), delta);
Assert.assertNotEquals(expected, DoubleRounder.round(value, places), delta); // Returns: 260.77 ! Assert.assertNotEquals(expected, DoubleRounder.round(value, places), delta); // Returns: 260.77 !
value = 90080070060.1d; value = 90080070060.1d;
places = 9; places = 9;
expected = 90080070060.1d; expected = 90080070060.1d;
Assert.assertEquals(expected, Round.round(value, places), delta); Assert.assertEquals(expected, Round.round(value, places), delta);
Assert.assertEquals(expected, Round.roundNotPrecise(value, places), delta); Assert.assertEquals(expected, Round.roundNotPrecise(value, places), delta);
Assert.assertNotEquals(expected, Round.roundAvoid(value, places), delta); // Returns: 9.223372036854776E9 ! Assert.assertNotEquals(expected, Round.roundAvoid(value, places), delta); // Returns: 9.223372036854776E9 !
Assert.assertEquals(expected, Precision.round(value, places), delta); Assert.assertEquals(expected, Precision.round(value, places), delta);
Assert.assertEquals(expected, DoubleRounder.round(value, places), delta); Assert.assertEquals(expected, DoubleRounder.round(value, places), delta);
} }
} }

View File

@ -1,106 +1,106 @@
package com.baeldung.numberofdigits; package com.baeldung.numberofdigits;
import org.junit.Assert; import org.junit.Assert;
import org.junit.Assume; import org.junit.Assume;
import org.junit.experimental.theories.DataPoints; import org.junit.experimental.theories.DataPoints;
import org.junit.experimental.theories.Theories; import org.junit.experimental.theories.Theories;
import org.junit.experimental.theories.Theory; import org.junit.experimental.theories.Theory;
import org.junit.runner.RunWith; import org.junit.runner.RunWith;
@RunWith(Theories.class) @RunWith(Theories.class)
public class NumberOfDigitsIntegrationTest { public class NumberOfDigitsIntegrationTest {
private static NumberOfDigits numberOfDigits; private static NumberOfDigits numberOfDigits;
static { static {
numberOfDigits = new NumberOfDigits(); numberOfDigits = new NumberOfDigits();
} }
@DataPoints @DataPoints
public static int[][] lowestIntegers() public static int[][] lowestIntegers()
{ {
return new int[][]{ return new int[][]{
{1, 1}, {1, 1},
{2, 10}, {2, 10},
{3, 100}, {3, 100},
{4, 1000}, {4, 1000},
{5, 10000}, {5, 10000},
{6, 100000}, {6, 100000},
{7, 1000000}, {7, 1000000},
{8, 10000000}, {8, 10000000},
{9, 100000000}, {9, 100000000},
{10, 1000000000} {10, 1000000000}
}; };
} }
@DataPoints @DataPoints
public static int[][] highestIntegers() public static int[][] highestIntegers()
{ {
return new int[][]{ return new int[][]{
{1, 9}, {1, 9},
{2, 99}, {2, 99},
{3, 999}, {3, 999},
{4, 9999}, {4, 9999},
{5, 99999}, {5, 99999},
{6, 999999}, {6, 999999},
{7, 9999999}, {7, 9999999},
{8, 99999999}, {8, 99999999},
{9, 999999999}, {9, 999999999},
{10, Integer.MAX_VALUE} {10, Integer.MAX_VALUE}
}; };
} }
@DataPoints @DataPoints
public static int[][] randomIntegers() public static int[][] randomIntegers()
{ {
return new int[][]{ return new int[][]{
{1, 1}, {1, 1},
{2, 14}, {2, 14},
{3, 549}, {3, 549},
{4, 1136}, {4, 1136},
{5, 25340}, {5, 25340},
{6, 134321}, {6, 134321},
{7, 1435432}, {7, 1435432},
{8, 54234129}, {8, 54234129},
{9, 113683912}, {9, 113683912},
{10, 1534031982} {10, 1534031982}
}; };
} }
@Theory @Theory
public void givenDataPoints_whenStringBasedSolutionInvoked_thenAllPointsMatch(final int[] entry) { public void givenDataPoints_whenStringBasedSolutionInvoked_thenAllPointsMatch(final int[] entry) {
Assume.assumeTrue(entry[0] > 0 && entry[1] > 0); Assume.assumeTrue(entry[0] > 0 && entry[1] > 0);
Assert.assertEquals(entry[0], numberOfDigits.stringBasedSolution(entry[1])); Assert.assertEquals(entry[0], numberOfDigits.stringBasedSolution(entry[1]));
} }
@Theory @Theory
public void givenDataPoints_whenLogarithmicApproachInvoked_thenAllPointsMatch(final int[] entry) { public void givenDataPoints_whenLogarithmicApproachInvoked_thenAllPointsMatch(final int[] entry) {
Assume.assumeTrue(entry[0] > 0 && entry[1] > 0); Assume.assumeTrue(entry[0] > 0 && entry[1] > 0);
Assert.assertEquals(entry[0], numberOfDigits.logarithmicApproach(entry[1])); Assert.assertEquals(entry[0], numberOfDigits.logarithmicApproach(entry[1]));
} }
@Theory @Theory
public void givenDataPoints_whenRepeatedMultiplicationInvoked_thenAllPointsMatch(final int[] entry) { public void givenDataPoints_whenRepeatedMultiplicationInvoked_thenAllPointsMatch(final int[] entry) {
Assume.assumeTrue(entry[0] > 0 && entry[1] > 0); Assume.assumeTrue(entry[0] > 0 && entry[1] > 0);
Assert.assertEquals(entry[0], numberOfDigits.repeatedMultiplication(entry[1])); Assert.assertEquals(entry[0], numberOfDigits.repeatedMultiplication(entry[1]));
} }
@Theory @Theory
public void givenDataPoints_whenShiftOperatorsInvoked_thenAllPointsMatch(final int[] entry) { public void givenDataPoints_whenShiftOperatorsInvoked_thenAllPointsMatch(final int[] entry) {
Assume.assumeTrue(entry[0] > 0 && entry[1] > 0); Assume.assumeTrue(entry[0] > 0 && entry[1] > 0);
Assert.assertEquals(entry[0], numberOfDigits.shiftOperators(entry[1])); Assert.assertEquals(entry[0], numberOfDigits.shiftOperators(entry[1]));
} }
@Theory @Theory
public void givenDataPoints_whenDividingWithPowersOf2Invoked_thenAllPointsMatch(final int[] entry) { public void givenDataPoints_whenDividingWithPowersOf2Invoked_thenAllPointsMatch(final int[] entry) {
Assume.assumeTrue(entry[0] > 0 && entry[1] > 0); Assume.assumeTrue(entry[0] > 0 && entry[1] > 0);
Assert.assertEquals(entry[0], numberOfDigits.dividingWithPowersOf2(entry[1])); Assert.assertEquals(entry[0], numberOfDigits.dividingWithPowersOf2(entry[1]));
} }
@Theory @Theory
public void givenDataPoints_whenDivideAndConquerInvoked_thenAllPointsMatch(final int[] entry) { public void givenDataPoints_whenDivideAndConquerInvoked_thenAllPointsMatch(final int[] entry) {
Assume.assumeTrue(entry[0] > 0 && entry[1] > 0); Assume.assumeTrue(entry[0] > 0 && entry[1] > 0);
Assert.assertEquals(entry[0], numberOfDigits.divideAndConquer(entry[1])); Assert.assertEquals(entry[0], numberOfDigits.divideAndConquer(entry[1]));
} }
} }

View File

@ -123,6 +123,10 @@
<module>java-collections-conversions-2</module> <module>java-collections-conversions-2</module>
<module>java-collections-maps-3</module> <module>java-collections-maps-3</module>
<module>pre-jpms</module> <module>pre-jpms</module>
<module>java-numbers</module>
<module>java-numbers-2</module>
<module>java-numbers-3</module>
<module>java-numbers-4</module>
</modules> </modules>
<dependencyManagement> <dependencyManagement>

Some files were not shown because too many files have changed in this diff Show More