forked from sudan92hard/OdometerProblem
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathProceduralOdometer.java
89 lines (73 loc) · 1.95 KB
/
ProceduralOdometer.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
88
89
import java.io.*;
import java.util.*;
public class ProceduralOdometer {
public static boolean isValidDistance(String number){
for(int i = 0; i < number.length() - 1; i++){
if(number.charAt(i) >= number.charAt(i + 1))
return false;
}
return true;
}
public static String getMinimumDistance(int digits){
if(digits <= 0 || digits > 10)
return "";
String number = "";
for(int i = 0; i < digits; i++){
number += i;
}
return number;
}
public static String getMaximumDistance(int digits){
if(digits <= 0 || digits > 10)
return "";
String number = "";
for(int i = digits; i > 0; i--){
number += (10 - i);
}
return number;
}
public static String getNextReading(String distance)
{
if(!isValidDistance(distance))
return "Invalid Distance";
if(distance.equals(getMaximumDistance(distance.length())))
return getMinimumDistance(distance.length());
int numOfDigits = distance.length();
char[] charArrayDistance = distance.toCharArray();
if(charArrayDistance[numOfDigits - 1] - '0' < 9)
{
charArrayDistance[numOfDigits - 1] += 1;
//System.out.println(new String(charArrayDistance));
return new String(charArrayDistance);
}
for(int i = numOfDigits - 1 ; i > 0 ; i--)
{
if(charArrayDistance[i] - charArrayDistance[i - 1] > 1)
{
charArrayDistance[i - 1] += 1;
for(int j = i ; j < numOfDigits ; j++)
{
charArrayDistance[j] = (char) (charArrayDistance[j-1] + 1);
}
break;
}
}
return new String(charArrayDistance);
}
public static String getNthDistance(String startReading, int N)
{
while(N != 0)
{
startReading = getNextReading(startReading);
N--;
}
return startReading;
}
public static void main(String args[]){
int digits = 4;
String minimumDistance = getMinimumDistance(digits);
String maximumDistance = getMaximumDistance(digits);
String nextDistance = getNextReading(minimumDistance);
System.out.println(getNthDistance("6789",4));
}
}