Skip to content
Related Articles
Get the best out of our app
GeeksforGeeks App
Open App
geeksforgeeks
Browser
Continue

Related Articles

Program for Octal to Decimal Conversion

Improve Article
Save Article
Like Article
Improve Article
Save Article
Like Article

Given an octal number as input, we need to write a program to convert the given octal number into equivalent decimal number.

Examples:

Input : 67
Output: 55

Input : 512
Output: 330

Input : 123
Output: 83

The idea is to extract the digits of a given octal number starting from the rightmost digit and keep a variable dec_value. At the time of extracting digits from the octal number, multiply the digit with the proper base (Power of 8) and add it to the variable dec_value. In the end, the variable dec_value will store the required decimal number.

For Example: 

If the octal number is 67. 

dec_value = 6*(8^1) + 7*(8^0) = 55

The below diagram explains how to convert an octal number (123) to an equivalent decimal value:  

Below is the implementation of the above idea. 

C++




// C++ program to convert octal to decimal
#include <iostream>
using namespace std;
 
// Function to convert octal to decimal
int octalToDecimal(int n)
{
    int num = n;
    int dec_value = 0;
 
    // Initializing base value to 1, i.e 8^0
    int base = 1;
 
    int temp = num;
    while (temp) {
 
        // Extracting last digit
        int last_digit = temp % 10;
        temp = temp / 10;
 
        // Multiplying last digit with appropriate
        // base value and adding it to dec_value
        dec_value += last_digit * base;
 
        base = base * 8;
    }
 
    return dec_value;
}
 
// Driver program to test above function
int main()
{
    int num = 67;
 
    cout << octalToDecimal(num) << endl;
}

Java




// Java program to convert octal to decimal
import java.io.*;
 
class GFG {
 
    // Function to convert octal to decimal
    static int octalToDecimal(int n)
    {
        int num = n;
        int dec_value = 0;
 
        // Initializing base value to 1, i.e 8^0
        int base = 1;
 
        int temp = num;
        while (temp > 0) {
            // Extracting last digit
            int last_digit = temp % 10;
            temp = temp / 10;
 
            // Multiplying last digit with appropriate
            // base value and adding it to dec_value
            dec_value += last_digit * base;
 
            base = base * 8;
        }
        return dec_value;
    }
 
    // driver program
    public static void main(String[] args)
    {
        int num = 67;
        System.out.println(octalToDecimal(num));
    }
}
 
// This code is contributed
// by Pramod Kumar

Python3




# Python3 program to convert
# octal to decimal
 
# Function to convert
# octal to decimal
 
 
def octalToDecimal(n):
 
    num = n
    dec_value = 0
 
    # Initializing base value
    # to 1, i.e 8^0
    base = 1
 
    temp = num
    while (temp):
 
        # Extracting last digit
        last_digit = temp % 10
        temp = int(temp / 10)
 
        # Multiplying last digit
        # with appropriate base
        # value and adding it
        # to dec_value
        dec_value += last_digit * base
 
        base = base * 8
 
    return dec_value
 
 
# Driver Code
num = 67
print(octalToDecimal(num))
 
# This code is contributed by mits

C#




// C# program to convert octal to
// decimal
using System;
 
class GFG {
 
    // Function to convert octal
    // to decimal
    static int octalToDecimal(int n)
    {
        int num = n;
        int dec_value = 0;
 
        // Initializing base value
        // to 1, i.e 8^0
        int b_ase = 1;
 
        int temp = num;
        while (temp > 0) {
 
            // Extracting last digit
            int last_digit = temp % 10;
            temp = temp / 10;
 
            // Multiplying last digit
            // with appropriate base
            // value and adding it to
            // dec_value
            dec_value += last_digit * b_ase;
 
            b_ase = b_ase * 8;
        }
        return dec_value;
    }
 
    // driver program
    public static void Main()
    {
        int num = 67;
 
        Console.WriteLine(octalToDecimal(num));
    }
}
 
// This code is contributed by vt_m.

PHP




<?php
// PHP program to convert octal to decimal
 
// Function to convert
// octal to decimal
function octalToDecimal($n)
{
     
    $num = $n;
    $dec_value = 0;
 
    // Initializing base value
    // to 1, i.e 8^0
    $base = 1;
 
    $temp = $num;
    while ($temp)
    {
 
        // Extracting last digit
        $last_digit = $temp % 10;
        $temp = $temp / 10;
 
        // Multiplying last digit
        // with appropriate base
        // value and adding it
        // to dec_value
        $dec_value += $last_digit * $base;
 
        $base = $base * 8;
    }
 
    return $dec_value;
}
 
    // Driver Code
    $num = 67;
    echo octalToDecimal($num);
     
// This code is contributed by anuj_67
?>

Javascript




<script>
 
// JavaScript program to convert octal to decimal
 
// Function to convert octal to decimal
function octalToDecimal(n)
{
    let num = n;
    let dec_value = 0;
 
    // Initializing base value to 1, i.e 8^0
    let base = 1;
 
    let temp = num;
    while (temp) {
 
        // Extracting last digit
        let last_digit = temp % 10;
        temp = Math.floor(temp / 10);
 
        // Multiplying last digit with appropriate
        // base value and adding it to dec_value
        dec_value += last_digit * base;
 
        base = base * 8;
    }
 
    return dec_value;
}
 
// Driver program to test above function
 
    let num = 67;
 
    document.write(octalToDecimal(num) + "<br>");
 
 
// This code is contributed by Surbhi Tyagi
 
</script>

Output

55

Time complexity: O(logN) where N is the given number
Auxiliary space: O(1)

Method: Using look up table method

The function octalToDecimal takes an integer n as input, which represents the octal number that needs to be converted to decimal. It initializes an unordered map lookup that maps each octal digit to its decimal equivalent.

It then uses a loop to extract each digit of the octal number from right to left, starting from the least significant digit. For each digit, it multiplies the decimal equivalent of the digit (retrieved from the lookup table) with the appropriate power of 8 (base) and adds it to the decimal variable. The base variable is updated after each iteration by multiplying it with 8. The loop continues until all digits have been processed.

Finally, the decimal variable is returned as the output of the function.

In the main function, an octal number octal_num is initialized and passed as an argument to the octalToDecimal function. The resulting decimal value is printed to the console.

C++




#include <iostream>
#include <unordered_map>
using namespace std;
 
int octalToDecimal(int n) {
    unordered_map<int, int> lookup{
        {0, 0}, {1, 1}, {2, 2}, {3, 3},
        {4, 4}, {5, 5}, {6, 6}, {7, 7}
    };
    int decimal = 0;
    int base = 1;
    while (n > 0) {
        int last_digit = n % 10;
        decimal += lookup[last_digit] * base;
        n /= 10;
        base *= 8;
    }
    return decimal;
}
 
int main() {
    int octal_num = 67;
    cout << octalToDecimal(octal_num) << endl;
    return 0;
}

Output

55

Time complexity: The time complexity of this algorithm is O(log N), where N is the octal number being converted to decimal. This is because we loop through each digit in the octal number once, and the number of digits in an N-digit octal number is log N.

Auxiliary space: The space complexity of this algorithm is O(1), as we only store a fixed-size lookup table and a few integer variables for the running sum and base value.

Using predefined function

C++




// C++ program to convert octal to decimal
#include <iostream>
using namespace std;
int OctToDec(string n)
{
  return stoi(n, 0, 8);
}
int main()
{
 
  string n = "67";
  cout << OctToDec(n);
  return 0;
}
 
// This code is contributed by phasing17

Java




// Java program to convert octal to decimal
import java.io.*;
 
class GFG {
    public static int OctToDec(String n)
    {
        return Integer.parseInt(n, 8);
    }
    public static void main(String[] args)
    {
 
        String n = "67";
        System.out.println(OctToDec(n));
    }
}

Python3




# Python program to convert octal to decimal
def OctToDec(n):
    return int(n, 8);
 
if __name__ == '__main__':
 
    n = "67";
    print(OctToDec(n));
     
# This code is contributed by 29AjayKumar

C#




using System;
 
public class GFG{
     
    public static int OctToDec(String n)
    {
        return Convert.ToInt32(n, 8);
    }
     
    static public void Main (){
         
        string n = "67";
        Console.WriteLine(OctToDec(n));
    }
}
 
// THIS CODE IS CONTRIBUTED BY RAG2127

Javascript




<script>
// javascript program to convert octal to decimal
   function OctToDec(n)
    {
        return parseInt(n, 8);
    }
     
   var n = "67";
   document.write(OctToDec(n));
// This code contributed by Princi Singh
</script>

Output

55

 

Method 3: Using recursion

1. The method uses the fact that each digit of an octal number represents a power of 8, starting from the rightmost digit. 

2. The method extracts the rightmost digit of the octal number by taking the remainder of the number divided by 10 (i.e., octal % 10) and adds it to the product of the remaining digits and the appropriate power of 8 (i.e., 8 * octal_to_decimal(octal // 10)).

3.This recursive step continues until the entire number has been converted to decimal.

Python3




def octal_to_decimal(octal):
    if octal == 0:
        return 0
    else:
        return (octal % 10) + 8 * octal_to_decimal(octal // 10)
octal=67
print(octal_to_decimal(octal))

C++




#include <iostream>
using namespace std;
 
int octal_to_decimal(int octal) {
    if (octal == 0) {
        return 0;
    } else {
        return (octal % 10) + 8 * octal_to_decimal(octal / 10);
    }
}
 
int main() {
    int octal = 67;
    cout << octal_to_decimal(octal) << endl;
    return 0;
}

Javascript




// Javascript program for the above approach
 
function octal_to_decimal(octal) {
  if (octal == 0) {
    return 0;
  } else {
    return (octal % 10) + 8 * octal_to_decimal(Math.floor(octal / 10));
  }
}
 
let octal = 67;
console.log(octal_to_decimal(octal));
 
// This code is contributed by rishabmalhdijo

Java




public class OctalToDecimal {
    public static int octalToDecimal(int octal) {
        if (octal == 0) {
            return 0;
        } else {
            return (octal % 10) + 8 * octalToDecimal(octal / 10);
        }
    }
 
    public static void main(String[] args) {
        int octal = 67;
        System.out.println(octalToDecimal(octal));
    }
}

C#




using System;
 
public class Program
{
    public static void Main()
    {
        int octal = 67;
        int decimalNum = OctalToDecimal(octal);
        Console.WriteLine(decimalNum);
    }
     
    public static int OctalToDecimal(int octal)
    {
        if (octal == 0)
        {
            return 0;
        }
        else
        {
            return (octal % 10) + 8 * OctalToDecimal(octal / 10);
        }
    }
}

Output

55

The time complexity of this method is O(log n), where n is the given number

Auxiliary space: O(log n), where n is the given number

This article is contributed by Harsh Agarwal. If you like GeeksforGeeks and would like to contribute, you can also write an article using write.geeksforgeeks.org or mail your article to review-team@geeksforgeeks.org. See your article appearing on the GeeksforGeeks main page and help other Geeks.

Please write comments if you find anything incorrect, or you want to share more information about the topic discussed above. 


My Personal Notes arrow_drop_up
Last Updated : 24 Apr, 2023
Like Article
Save Article
Similar Reads