forked from phishman3579/java-algorithms-implementation
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathDivision.java
87 lines (75 loc) · 2.68 KB
/
Division.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
package com.jwetherell.algorithms.mathematics;
public class Division {
public static final long division(int a, int b) {
long result = ((long) a) / ((long) b);
return result;
}
public static final long divisionUsingLoop(int a, int b) {
int absA = Math.abs(a);
int absB = Math.abs(b);
long temp = absA;
long result = 0;
while (temp >= 0) {
temp -= absB;
if (temp >= 0)
result++;
}
return (a > 0 && b > 0 || a < 0 && b < 0) ? result : -result;
}
public static final long divisionUsingRecursion(int a, int b) {
int absA = Math.abs(a);
int absB = Math.abs(b);
long result = 1;
int diff = absA - absB;
if (diff > 0 && diff <= 1) {
return result;
} else if (diff < 0) {
return 0;
}
result += divisionUsingRecursion(diff, absB);
return (a > 0 && b > 0 || a < 0 && b < 0) ? result : -result;
}
public static final long divisionUsingMultiplication(int a, int b) {
int absA = Math.abs(a);
int absB = Math.abs(b);
int temp = absB;
int counter = 0;
while (temp <= absA) {
temp = temp << 1;
counter++;
}
absA -= absB << (counter - 1);
long result = (long) Math.pow(2, counter - 1);
if (absB <= absA)
result += divisionUsingMultiplication(absA, absB);
return (a > 0 && b > 0 || a < 0 && b < 0) ? result : -result;
}
public static final long divisionUsingShift(int a, int b) {
int absA = Math.abs(a);
int absB = Math.abs(b);
int tempA, tempB, counter;
long result = 0L;
while (absA >= absB) {
tempA = absA >> 1; // Right shift "a"
tempB = absB;
counter = 1;
while (tempA >= tempB) { // Double "tempB" until it's larger than
// "tempA"
tempB <<= 1;
counter <<= 1; // Double the counter
}
absA -= tempB; // Subtract "tempB" from "a"
result += counter; // Add counter (2^number of left shifts)
}
return (a > 0 && b > 0 || a < 0 && b < 0) ? result : -result;
}
public static final long divisionUsingLogs(int a, int b) {
long absA = Math.abs(a);
long absB = Math.abs(b);
double logBase10A = Math.log10(absA);
double logBase10B = Math.log10(absB);
double powOf10 = Math.pow(10, (logBase10A - logBase10B));
long result = (long) Math.floor(powOf10);
return (a > 0 && b > 0 || a < 0 && b < 0) ? result : -result;
}
}