-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathKing.java
More file actions
91 lines (81 loc) · 2.74 KB
/
King.java
File metadata and controls
91 lines (81 loc) · 2.74 KB
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
90
91
import java.util.Comparator;
import java.util.HashMap;
import java.util.HashSet;
/**
* Created by ignacio ojanguren on 27/10/16.
*/
public class King implements Comparable<King>{
private String nameKing;
private String romanNumber;
private Integer numberKing;
public King(String nameKing, String romanNumber){
this.nameKing = nameKing;
this.romanNumber = romanNumber;
this.numberKing = 0;
convertRomanToNumber();
}
public void setNameKing(String nameKing){
this.nameKing = nameKing;
}
public void setRomanNumber(String romanNumber){
this.romanNumber = romanNumber;
convertRomanToNumber();
}
public String getNameKing(){
return this.nameKing;
}
public String getRomanNumber(){
return this.romanNumber;
}
public int getNumberKing(){
return numberKing;
}
/**
* This class convert a Roman number to an integer
* @postcondition:
* sets the variable numberKing to the value it should have.
*/
public void convertRomanToNumber(){
//{'I', 'V', 'X', 'L','C', 'D', 'M'} //Roman
//{ 1, 5, 10, 50, 100, 500, 1000}//The value in int
HashMap<Character, Integer> translationNumbers = new HashMap<Character, Integer>();
translationNumbers.put(' ',0);
translationNumbers.put('I', 1);
translationNumbers.put('V', 5);
translationNumbers.put('X', 10);
translationNumbers.put('L', 50);
translationNumbers.put('C',100);
translationNumbers.put('D',500);
translationNumbers.put('M',1000);
char previous = ' ';
int total = 0;
for (char letter: this.romanNumber.toCharArray()) {
if(translationNumbers.get(letter) <= translationNumbers.get(previous)){
total += translationNumbers.get(letter);
}else if(translationNumbers.get(letter) > translationNumbers.get(previous)){
total += translationNumbers.get(letter) - translationNumbers.get(previous) * 2;
}
previous = letter;
}
this.numberKing = total;
}
/**
* Override the compareTo class adding the numbers of the Kings to compare.
* @param k1
* The object King is passed to the method
* @return
* Returns an integer indicating if the comparisons are smaller than the previous king, it returns a number
* bigger than 0
*/
@Override
public int compareTo(King k1) {
int lastKing = nameKing.compareTo(k1.nameKing);
if(lastKing == 0){
lastKing = k1.numberKing.compareTo(numberKing);
}
return lastKing;
}
public String toString(){
return nameKing + " the " + romanNumber;
}
}