给定一个数字N (<10 10 ),任务是找到表示 N 所需的最小阶乘数,作为它们的总和。另外,打印这些阶乘。
例子:
Input: N = 30
Output: 2
24, 6
Explanation:
Factorials needed to represent 30: 24, 6
Input: N = 150
Output: 3
120, 24, 6
Explanation:
Factorials needed to represent 150: 120 24 6
方法:
- 为了有效地找到将 N 表示为它们的总和所需的阶乘,我们可以预先计算这些阶乘直到 N (N < 10 10 ) 并将它们存储在一个数组中,以便更快地计算。
- 然后使用贪心算法,我们可以从这个数组中取出最大的阶乘,可以将其相加来表示 N。
- 从最大可能的阶乘开始,并在剩余值大于 0 时继续添加阶乘。
- 下面是完整的算法。
- 将结果初始化为空
- 找到小于 N 的最大阶乘
- 将找到的阶乘添加到结果中。从 N 中减去找到的阶乘的值
- 如果 N 变为 0,则打印结果。否则对 N 的新值重复步骤 2 和 3
下面是上述方法的实现:
C++
// C++ program to find minimum number of factorials
#include
#define ll long long int
using namespace std;
// Array to calculate all factorials
// less than or equal to N
// Since there can be only 14 factorials
// till 10^10
// Hence the maximum size of fact[] is 14
ll fact[14];
// Store the actual size of fact[]
int size = 1;
// Function to precompute factorials till N
void preCompute(int N)
{
// Precomputing factorials
fact[0] = 1;
for (int i = 1; fact[i - 1] <= N; i++) {
fact[i] = (fact[i - 1] * i);
size++;
}
}
// Function to find the minimum number
// of factorials whose sum represents N
void findMin(int N)
{
// Precompute factorials
preCompute(N);
int originalN = N;
// Initialize result
vector ans;
// Traverse through all factorials
for (int i = size - 1; i >= 0; i--) {
// Find factorials
while (N >= fact[i]) {
N -= fact[i];
ans.push_back(fact[i]);
}
}
// Print min count
cout << ans.size() << "\n";
// Print result
for (int i = 0; i < ans.size(); i++)
cout << ans[i] << " ";
}
// Driver program
int main()
{
int n = 27;
findMin(n);
return 0;
}
Java
// Java program to find minimum number of factorials
import java.util.*;
class GFG{
// Array to calculate all factorials
// less than or equal to N
// Since there can be only 14 factorials
// till 10^10
// Hence the maximum size of fact[] is 14
static int []fact = new int[14];
// Store the actual size of fact[]
static int size = 1;
// Function to precompute factorials till N
static void preCompute(int N)
{
// Precomputing factorials
fact[0] = 1;
for (int i = 1; fact[i - 1] <= N; i++) {
fact[i] = (fact[i - 1] * i);
size++;
}
}
// Function to find the minimum number
// of factorials whose sum represents N
static void findMin(int N)
{
// Precompute factorials
preCompute(N);
int originalN = N;
// Initialize result
Vector ans = new Vector();
// Traverse through all factorials
for (int i = size - 1; i >= 0; i--) {
// Find factorials
while (N >= fact[i]) {
N -= fact[i];
ans.add(fact[i]);
}
}
// Print min count
System.out.print(ans.size()+ "\n");
// Print result
for (int i = 0; i < ans.size(); i++)
System.out.print(ans.get(i)+ " ");
}
// Driver program
public static void main(String[] args)
{
int n = 27;
findMin(n);
}
}
// This code is contributed by PrinciRaj1992
Python3
# Python3 program to find minimum number of factorials
# Array to calculate all factorials
# less than or equal to N
# Since there can be only 14 factorials
# till 10^10
# Hence the maximum size of fact[] is 14
fact = [0]*14
# Store the actual size of fact[]
size = 1
# Function to precompute factorials till N
def preCompute(N):
global size
# Precomputing factorials
fact[0] = 1
i = 1
while fact[i - 1] <= N:
fact[i] = fact[i - 1] * i
size += 1
i += 1
# Function to find the minimum number
# of factorials whose sum represents N
def findMin(N):
# Precompute factorials
preCompute(N)
originalN = N
# Initialize result
ans = []
# Traverse through all factorials
for i in range(size-1, -1, -1):
# Find factorials
while (N >= fact[i]):
N -= fact[i]
ans.append(fact[i])
# Prmin count
print(len(ans))
# Prresult
for i in ans:
print(i, end=" ")
# Driver program
n = 27
findMin(n)
# This code is contributed by mohit kumar 29
C#
// C# program to find minimum number of factorials
using System;
using System.Collections.Generic;
class GFG{
// Array to calculate all factorials
// less than or equal to N
// Since there can be only 14 factorials
// till 10^10
// Hence the maximum size of fact[] is 14
static int []fact = new int[14];
// Store the actual size of fact[]
static int size = 1;
// Function to precompute factorials till N
static void preCompute(int N)
{
// Precomputing factorials
fact[0] = 1;
for (int i = 1; fact[i - 1] <= N; i++) {
fact[i] = (fact[i - 1] * i);
size++;
}
}
// Function to find the minimum number
// of factorials whose sum represents N
static void findMin(int N)
{
// Precompute factorials
preCompute(N);
int originalN = N;
// Initialize result
List ans = new List();
// Traverse through all factorials
for (int i = size - 1; i >= 0; i--) {
// Find factorials
while (N >= fact[i]) {
N -= fact[i];
ans.Add(fact[i]);
}
}
// Print min count
Console.Write(ans.Count+ "\n");
// Print result
for (int i = 0; i < ans.Count; i++)
Console.Write(ans[i]+ " ");
}
// Driver program
public static void Main(String[] args)
{
int n = 27;
findMin(n);
}
}
// This code is contributed by PrinciRaj1992
Javascript
输出:
3
24 2 1
如果您希望与专家一起参加现场课程,请参阅DSA 现场工作专业课程和学生竞争性编程现场课程。