Created
September 20, 2017 13:19
-
-
Save javamultiplex/87e237b2c41c50636d35492c24a42f6e to your computer and use it in GitHub Desktop.
Hexadecimal to Octal Converter
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
package com.javamultiplex.baseconversion; | |
import java.util.Scanner; | |
/** | |
* | |
* @author Rohit Agarwal | |
* @category Base Conversion | |
* @problem Convert Hexadecimal to Octal | |
* | |
*/ | |
public class HexadecimalToOctal { | |
public static void main(String[] args) { | |
Scanner input = null; | |
try { | |
input = new Scanner(System.in); | |
System.out.println("Enter hexadecimal number : "); | |
String number = input.next(); | |
if (isHexadecimalNumber(number)) { | |
String octal = getOctalFromHexadecimalNumber(number); | |
System.out.println("Octal Number : " + octal); | |
} else { | |
System.out.println("Please enter valid hexadecimal number."); | |
} | |
} finally { | |
if (input != null) { | |
input.close(); | |
} | |
} | |
} | |
private static String getOctalFromHexadecimalNumber(String number) { | |
// Convert Hexadecimal to Decimal | |
int decimal = getDecimalFromHexadecimalNumber(number); | |
// Convert Decimal to Octal | |
String octal = getOctalFromDecimalNumber(decimal); | |
return octal; | |
} | |
private static String getOctalFromDecimalNumber(int decimal) { | |
int remainder = 0; | |
StringBuilder octal = new StringBuilder(); | |
while (decimal != 0) { | |
remainder = decimal % 8; | |
// Converting Integer to String and adding into StringBuilder. | |
octal.append(String.valueOf(remainder)); | |
decimal = decimal / 8; | |
} | |
// Reverse String using library function of StringBuilder class. | |
return octal.reverse().toString(); | |
} | |
private static int getDecimalFromHexadecimalNumber(String number) { | |
// Converting String to StringBuilder. | |
StringBuilder string = new StringBuilder(number); | |
string = string.reverse(); | |
int length = string.length(); | |
int digit, power, sum = 0; | |
for (int i = 0; i < length; i++) { | |
if (Character.isDigit(string.charAt(i))) { | |
digit = string.charAt(i) - 48; | |
} else { | |
digit = getHexadecimalCharacterDigit(string.charAt(i)); | |
} | |
power = (int) Math.pow(16, i); | |
sum = sum + digit * power; | |
} | |
return sum; | |
} | |
private static int getHexadecimalCharacterDigit(char ch) { | |
int digit = 0; | |
switch (ch) { | |
case 'A': | |
case 'a': | |
digit = 10; | |
break; | |
case 'B': | |
case 'b': | |
digit = 11; | |
break; | |
case 'C': | |
case 'c': | |
digit = 12; | |
break; | |
case 'D': | |
case 'd': | |
digit = 13; | |
break; | |
case 'E': | |
case 'e': | |
digit = 14; | |
break; | |
case 'F': | |
case 'f': | |
digit = 15; | |
break; | |
} | |
return digit; | |
} | |
private static boolean isHexadecimalNumber(String number) { | |
/* | |
* Regular expression that matches string containing only digits [0-9] | |
* and alphabets [A-F] or [a-f] | |
*/ | |
String pattern = "^[0-9a-fA-F]+$"; | |
boolean result = false; | |
if (number.matches(pattern)) { | |
result = true; | |
} | |
return result; | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment