Wednesday, January 8, 2025
Google search engine
HomeData Modelling & AIPrint factorials of a range in right aligned format

Print factorials of a range in right aligned format

Given two numbers m and n, the task is to find factorial of all numbers including m and n, and then print below format.
Examples: 
 

Input : 6 10
Output :
     720
    5040
   40320
  362880
 3628800

Input : 10 20
Output :
             3628800
            39916800
           479001600
          6227020800
         87178291200
       1307674368000
      20922789888000
     355687428096000
    6402373705728000
  121645100408832000
 2432902008176640000

 

We used the boost multiprecision library for store the factorial of large number and print the factorial with the setw() function. 
setw(int) -> setw(int) is a function is used for intention in the result.
 

C++




// CPP Program to print format of factorial
#include <boost/multiprecision/cpp_int.hpp>
#include <iostream>
#include <vector>
using namespace std;
using boost::multiprecision::cpp_int;
 
vector<cpp_int> find_factorial(int num1, int num2)
{
    // vector for store the result
    vector<cpp_int> vec;
 
    // variable for store the
    // each number factorial
    cpp_int fac = 1;
 
    // copy of first number
    int temp = num1;
 
    // found first number factorial
    while (1) {
        if (temp == 1)
            break;
        fac *= temp;
        temp--;
    }
     
    // push the first number in result vector
    vec.push_back(fac);
 
    // increment the first number
    num1++;
 
    // found the all remaining number
    // factorial loop is working until
    // all required number factorial founded
    while (num1 <= num2) {
        fac *= num1;
 
        // store the result of factorial
        vec.push_back(fac);
 
        // increment the first number
        num1++;
    }
     
    // return the result
    return (vec);
}
 
// function for print the result
void print_format(vector<cpp_int>& result)
{
    // setw() is used for fill the blank
    // right is used for right justification of data
    int digits = result.back().str().size();
     
    for (int i = 0; i < result.size(); i++) {
         cout <<  setw(digits + 1) << 
                    right << result[i] <<  endl;
    }
}
 
// Driver function
int main()
{
     
    // number which found the factorial
    // of between range
    int m = 10, n = 20;
 
    // store the result of factorial
    vector<cpp_int> result_fac;
 
    // function for found factorial
    result_fac = find_factorial(m, n);
 
    // function for print format
    print_format(result_fac);
 
    return 0;
}


Java




// Java Program to print
// format of factorial
import java.util.*;
 
class GFG {
  static ArrayList<Long> find_factorial(int num1,
                                        int num2)
  {
    // vector for store
    // the result
    ArrayList<Long> vec = new ArrayList<Long>();
 
    // variable for store the
    // each number factorial
    long fac = 1;
 
    // copy of first number
    long temp = num1;
 
    // found first
    // number factorial
    while (true) {
      if (temp == 1)
        break;
      fac *= temp;
      temp--;
    }
 
    // push the first number
    // in result vector
    vec.add(fac);
 
    // increment the
    // first number
    num1++;
 
    // found the all remaining
    // number factorial loop
    // is working until all
    // required number
    // factorial founded
    while (num1 <= num2) {
      fac *= num1;
 
      // store the result
      // of factorial
      vec.add(fac);
 
      // increment
      // the first number
      num1++;
    }
 
    // return the result
    return (vec);
  }
 
  // function for
  // print the result
  static void print_format(ArrayList<Long> result)
  {
    // setw() is used for fill
    // the blank right is used
    // for right justification
    // of data
    int x = result.size();
    int digits  = String.valueOf(result.get(x - 1)).length();
 
    for (int i = 0; i < x; i++) {
      System.out.println(String.format(
        "%1$" + (digits + 1) + "s", result.get(i)));
    }
  }
 
  // Driver Code
 
  public static void main(String[] args)
  {
    // number which found
    // the factorial
    // of between range
    int m = 10;
    int n = 20;
 
    // store the result
    // of factorial
    // using
    // function for
    // found factorial
    var result_fac = find_factorial(m, n);
 
    // function for
    // print format
    print_format(result_fac);
  }
}
 
// This code is contributed
// by phasing17


Python




# Python Program to print
# format of factorial
def find_factorial(num1, num2):
 
    # vector for store
    # the result
    vec = []
 
    # variable for store the
    # each number factorial
    fac = 1
 
    # copy of first number
    temp = num1
 
    # found first
    # number factorial
    while (1):
        if (temp == 1):
            break
        fac *= temp
        temp = temp - 1
 
    # push the first number
    # in result vector
    vec.append(fac)
 
    # increment the
    # first number
    num1 = num1 + 1
 
    # found the all remaining
    # number factorial loop
    # is working until all
    # required number
    # factorial founded
    while (num1 <= num2):
        fac *= num1
 
        # store the result
        # of factorial
        vec.append(fac)
 
        # increment
        # the first number
        num1 = num1 + 1
 
    # return the result
    return (vec)
 
 
# function for
# print the result
def print_format(result):
 
    # setw() is used for fill
    # the blank right is used
    # for right justification
    # of data
    x = len(result)
 
    digits = len(str(result[x-1]))
 
    for i in range(x):
        # Creating a temp string of
        # empty spaces, to right
        # align them.
        tmp = ""
        for j in range(x-i):
            tmp = tmp + ' '
 
        result[i] = tmp + str(result[i])
        print(str(result[i]))
 
 
# Driver Code
 
# number which found
# the factorial
# of between range
m = 10
n = 20
 
# function for
# found factorial
result_fac = find_factorial(m, n)
 
# function for
# print format
print_format(result_fac)
 
# The code is contributed by Gautam goel (gautamgoel962)


C#




// C# Program to print
// format of factorial
 
using System;
using System.Collections.Generic;
 
class GFG
{
    static List<long> find_factorial(int num1, int num2)
    {
        // vector for store
        // the result
        List<long> vec = new List<long>();
 
        // variable for store the
        // each number factorial
        long fac = 1;
     
        // copy of first number
        long temp = num1;
     
        // found first
        // number factorial
        while (true)
        {
            if (temp == 1)
                break;
            fac *= temp;
            temp--;
        }
         
        // push the first number
        // in result vector
        vec.Add(fac);
     
        // increment the
        // first number
        num1++;
     
        // found the all remaining
        // number factorial loop
        // is working until all
        // required number
        // factorial founded
        while (num1 <= num2)
        {
            fac *= num1;
     
            // store the result
            // of factorial
            vec.Add(fac);
     
            // increment
            // the first number
            num1++;
        }
         
        // return the result
        return (vec);
    }
     
    // function for
    // print the result
    static void print_format(List<long> result)
    {
        // setw() is used for fill
        // the blank right is used
        // for right justification
        // of data
        int x = result.Count;
        int digits = Convert.ToString(result[x - 1]).Length;
         
        for (int i = 0; i < x; i++)
        {
        Console.WriteLine(Convert.ToString(result[i]).PadLeft(digits + 1));
        }
    }
     
    // Driver Code
     
    public static void Main(string[] args)
    {
        // number which found
        // the factorial
        // of between range
        int m = 10;
        int n = 20;
         
        // store the result
        // of factorial
        // using
        // function for
        // found factorial
        var result_fac = find_factorial(m, n);
         
        // function for
        // print format
        print_format(result_fac);
    }
}
 
// This code is contributed
// by phasing17


PHP




<?PHP
// PHP Program to print
// format of factorial
 
function find_factorial($num1,
                        $num2)
{
    // vector for store
    // the result
    $vec;
    $t = 0;
 
    // variable for store the
    // each number factorial
    $fac = 1;
 
    // copy of first number
    $temp = $num1;
 
    // found first
    // number factorial
    while (1)
    {
        if ($temp == 1)
            break;
        $fac *= $temp;
        $temp--;
    }
     
    // push the first number
    // in result vector
    $vec[$t++] = $fac;
 
    // increment the
    // first number
    $num1++;
 
    // found the all remaining
    // number factorial loop
    // is working until all
    // required number
    // factorial founded
    while ($num1 <= $num2)
    {
        $fac *= $num1;
 
        // store the result
        // of factorial
        $vec[$t++] = $fac;
 
        // increment
        // the first number
        $num1++;
    }
     
    // return the result
    return ($vec);
}
 
// function for
// print the result
function print_format($result)
{
    // setw() is used for fill
    // the blank right is used
    // for right justification
    // of data
    $x = count($result);
    $digits = strlen((string)$result[$x - 1]);
     
    for ($i = 0; $i < $x; $i++)
    {
        echo str_pad($result[$i], ($digits + 1),
                      " ", STR_PAD_LEFT) . "\n";
    }
}
 
// Driver Code
 
// number which found
// the factorial
// of between range
$m = 10;
$n = 20;
 
// store the result
// of factorial
$result_fac;
 
// function for
// found factorial
$result_fac = find_factorial($m, $n);
 
// function for
// print format
print_format($result_fac);
 
// This code is contributed
// by mits
?>


Javascript




<script>
 
// Javascript Program to print
// format of factorial
 
function find_factorial(num1, num2)
{
    // vector for store
    // the result
    let vec = [];
    let t = 0;
 
    // variable for store the
    // each number factorial
    let fac = 1;
 
    // copy of first number
    let temp = num1;
 
    // found first
    // number factorial
    while (1)
    {
        if (temp == 1)
            break;
        fac *= temp;
        temp--;
    }
     
    // push the first number
    // in result vector
    vec[t++] = fac;
 
    // increment the
    // first number
    num1++;
 
    // found the all remaining
    // number factorial loop
    // is working until all
    // required number
    // factorial founded
    while (num1 <= num2)
    {
        fac *= num1;
 
        // store the result
        // of factorial
        vec[t++] = fac;
 
        // increment
        // the first number
        num1++;
    }
     
    // return the result
    return (vec);
}
 
// function for
// print the result
function print_format(result)
{
    // setw() is used for fill
    // the blank right is used
    // for right justification
    // of data
    let x = result.length;
    let digits = String(result[x - 1]).length;
     
    for (let i = 0; i < x; i++)
    {
    result[i] = new Array(x - i).fill(" ").join(" ") +
    result[i];
      document.write(String(result[i]) + "<br>");
    }
}
 
// Driver Code
 
// number which found
// the factorial
// of between range
let m = 10;
let n = 20;
 
// store the result
// of factorial
let result_fac;
 
// function for
// found factorial
result_fac = find_factorial(m, n);
 
// function for
// print format
print_format(result_fac);
 
// This code is contributed
// by gfgking
 
</script>


Output:  

             3628800
            39916800
           479001600
          6227020800
         87178291200
       1307674368000
      20922789888000
     355687428096000
    6402373705728000
  121645100408832000
 2432902008176640000

Time complexity : O(n)

Space complexity : O(n)

Feeling lost in the world of random DSA topics, wasting time without progress? It’s time for a change! Join our DSA course, where we’ll guide you on an exciting journey to master DSA efficiently and on schedule.
Ready to dive in? Explore our Free Demo Content and join our DSA course, trusted by over 100,000 neveropen!

Last Updated :
22 Feb, 2023
Like Article
Save Article


Previous

<!–

8 Min Read | Java

–>


Next


<!–

8 Min Read | Java

–>

Dominic Rubhabha-Wardslaus
Dominic Rubhabha-Wardslaushttp://wardslaus.com
infosec,malicious & dos attacks generator, boot rom exploit philanthropist , wild hacker , game developer,
RELATED ARTICLES

Most Popular

Recent Comments