给定整数N ,任务是找到通过以下操作之一将N减小为0的最小移动数:
- 将N减少1。
- 如果N可被2整除,则将N减少为(N / 2)。
- 如果N可被3整除,则将N减少为(N / 3)。
例子:
Input: N = 10
Output: 4
Explanation:
Here N = 10
Step 1: Reducing N by 1 i.e., 10 – 1 = 9.
Step 2: Since 9 is divisible by 3, reduce it to N/3 = 9/3 = 3
Step 3: Since again 3 is divisible by 3 again repeating step 2, i.e., 3/3 = 1.
Step 4: 1 can be reduced by the step 1, i.e., 1-1 = 0
Hence, 4 steps are needed to reduce N to 0.
Input: N = 6
Output: 3
Explanation:
Here N = 6
Step 1: Since 6 is divisible by 2, then 6/2 =3
Step 2: since 3 is divisible by 3, then 3/3 = 1.
Step 3: Reduce N to N-1 by 1, 1-1 = 0.
Hence, 3 steps are needed to reduce N to 0.
天真的方法:这个想法是对所有可能的动作使用递归。步骤如下:
- 观察该问题的基本情况,如果N <2,则对于所有情况,答案都是N本身。
- 在N的每个值处,选择2种可能的情况:
- 减少n直到n%2 == 0,然后用count = 1 + n%2 + f(n / 2)更新n / = 2
- 减少n直到n%3 == 0,然后用count = 1 + n%3 + f(n / 3)更新n / = 3
- 两种计算都得出递归关系为:
count = 1 + min(n%2 + f(n/2), n%3 + f(n/3))
where, f(n) is the minimum of moves to reduce N to 0.
下面是上述方法的实现:
C++
// C++ program for the above approach
#include
using namespace std;
// Function to find the minimum
// number to steps to reduce N to 0
int minDays(int n)
{
// Base case
if (n < 1)
return n;
// Recursive call to count the
// minimum steps needed
int cnt = 1 + min(n % 2 + minDays(n / 2),
n % 3 + minDays(n / 3));
// Return the answer
return cnt;
}
// Driver Code
int main()
{
// Given number N
int N = 6;
// Function call
cout << minDays(N);
return 0;
}
// This code is contributed by 29AjayKumar
Java
// Java program for the above approach
class GFG{
// Function to find the minimum
// number to steps to reduce N to 0
static int minDays(int n)
{
// Base case
if (n < 1)
return n;
// Recursive Call to count the
// minimum steps needed
int cnt = 1 + Math.min(n % 2 + minDays(n / 2),
n % 3 + minDays(n / 3));
// Return the answer
return cnt;
}
// Driver Code
public static void main(String[] args)
{
// Given Number N
int N = 6;
// Function Call
System.out.print(minDays(N));
}
}
// This code is contributed by PrinciRaj1992
Python3
# Python3 program for the above approach
# Function to find the minimum
# number to steps to reduce N to 0
def minDays(n):
# Base case
if n < 1:
return n
# Recursive Call to count the
# minimum steps needed
cnt = 1 + min(n % 2 + minDays(n // 2),
n % 3 + minDays(n // 3))
# Return the answer
return cnt
# Driver Code
# Given Number N
N = 6
# Function Call
print(str(minDays(N)))
C#
// C# program for the above approach
using System;
class GFG{
// Function to find the minimum
// number to steps to reduce N to 0
static int minDays(int n)
{
// Base case
if (n < 1)
return n;
// Recursive call to count the
// minimum steps needed
int cnt = 1 + Math.Min(n % 2 + minDays(n / 2),
n % 3 + minDays(n / 3));
// Return the answer
return cnt;
}
// Driver Code
public static void Main(String[] args)
{
// Given number N
int N = 6;
// Function call
Console.Write(minDays(N));
}
}
// This code is contributed by Rajput-Ji
C++
// C++ program for
// the above approach
#include
using namespace std;
// Function to find the minimum
// number to steps to reduce N to 0
int count(int n)
{
// Dictionary for storing
// the precomputed sum
map dp;
// Bases Cases
dp[0] = 0;
dp[1] = 1;
// Check if n is not in dp then
// only call the function so as
// to reduce no of recursive calls
if ((dp.find(n) == dp.end()))
dp[n] = 1 + min(n % 2 +
count(n / 2), n % 3 +
count(n / 3));
// Return the answer
return dp[n];
}
// Driver Code
int main()
{
// Given number N
int N = 6;
// Function call
cout << count(N);
}
// This code is contributed by gauravrajput1
Java
// Java program for the above approach
import java.util.HashMap;
class GFG{
// Function to find the minimum
// number to steps to reduce N to 0
static int count(int n)
{
// Dictionary for storing
// the precomputed sum
HashMap dp = new HashMap();
// Bases Cases
dp.put(0, 0);
dp.put(1, 1);
// Check if n is not in dp then
// only call the function so as
// to reduce no of recursive calls
if (!dp.containsKey(n))
dp.put(n, 1 + Math.min(n % 2 +
count(n / 2), n % 3 +
count(n / 3)));
// Return the answer
return dp.get(n);
}
// Driver Code
public static void main(String[] args)
{
// Given number N
int N = 6;
// Function call
System.out.println(String.valueOf((count(N))));
}
}
// This code is contributed by Amit Katiyar
Python3
# Python3 program for the above approach
# Function to find the minimum
# number to steps to reduce N to 0
def count(n):
# Dictionary for storing
# the precomputed sum
dp = dict()
# Bases Cases
dp[0] = 0
dp[1] = 1
# Check if n is not in dp then
# only call the function so as
# to reduce no of recursive calls
if n not in dp:
dp[n] = 1 + min(n % 2 + count(n//2), n % 3 + count(n//3))
# Return the answer
return dp[n]
# Driver Code
# Given Number N
N = 6
# Function Call
print(str(count(N)))
C#
// C# program for the above approach
using System;
using System.Collections.Generic;
public class GFG{
// Function to find the minimum
// number to steps to reduce N to 0
static int count(int n)
{
// Dictionary for storing
// the precomputed sum
Dictionary dp = new Dictionary();
// Bases Cases
dp.Add(0, 0);
dp.Add(1, 1);
// Check if n is not in dp then
// only call the function so as
// to reduce no of recursive calls
if (!dp.ContainsKey(n))
dp.Add(n, 1 + Math.Min(n % 2 + count(n / 2),
n % 3 + count(n / 3)));
// Return the answer
return dp[n];
}
// Driver Code
public static void Main(String[] args)
{
// Given number N
int N = 6;
// Function call
Console.WriteLine(String.Join("",
(count(N))));
}
}
// This code is contributed by Rajput-Ji
4
时间复杂度: O(2 N )
辅助空间: O(1)
高效的方法:这个想法是使用动态编程。由于重复的子问题数量众多,上述递归方法导致了TLE的出现。为了使用字典来优化上述方法,以跟踪已经执行了递归调用的值,以减少进一步的计算,从而可以更快地访问值。
下面是上述方法的实现:
C++
// C++ program for
// the above approach
#include
using namespace std;
// Function to find the minimum
// number to steps to reduce N to 0
int count(int n)
{
// Dictionary for storing
// the precomputed sum
map dp;
// Bases Cases
dp[0] = 0;
dp[1] = 1;
// Check if n is not in dp then
// only call the function so as
// to reduce no of recursive calls
if ((dp.find(n) == dp.end()))
dp[n] = 1 + min(n % 2 +
count(n / 2), n % 3 +
count(n / 3));
// Return the answer
return dp[n];
}
// Driver Code
int main()
{
// Given number N
int N = 6;
// Function call
cout << count(N);
}
// This code is contributed by gauravrajput1
Java
// Java program for the above approach
import java.util.HashMap;
class GFG{
// Function to find the minimum
// number to steps to reduce N to 0
static int count(int n)
{
// Dictionary for storing
// the precomputed sum
HashMap dp = new HashMap();
// Bases Cases
dp.put(0, 0);
dp.put(1, 1);
// Check if n is not in dp then
// only call the function so as
// to reduce no of recursive calls
if (!dp.containsKey(n))
dp.put(n, 1 + Math.min(n % 2 +
count(n / 2), n % 3 +
count(n / 3)));
// Return the answer
return dp.get(n);
}
// Driver Code
public static void main(String[] args)
{
// Given number N
int N = 6;
// Function call
System.out.println(String.valueOf((count(N))));
}
}
// This code is contributed by Amit Katiyar
Python3
# Python3 program for the above approach
# Function to find the minimum
# number to steps to reduce N to 0
def count(n):
# Dictionary for storing
# the precomputed sum
dp = dict()
# Bases Cases
dp[0] = 0
dp[1] = 1
# Check if n is not in dp then
# only call the function so as
# to reduce no of recursive calls
if n not in dp:
dp[n] = 1 + min(n % 2 + count(n//2), n % 3 + count(n//3))
# Return the answer
return dp[n]
# Driver Code
# Given Number N
N = 6
# Function Call
print(str(count(N)))
C#
// C# program for the above approach
using System;
using System.Collections.Generic;
public class GFG{
// Function to find the minimum
// number to steps to reduce N to 0
static int count(int n)
{
// Dictionary for storing
// the precomputed sum
Dictionary dp = new Dictionary();
// Bases Cases
dp.Add(0, 0);
dp.Add(1, 1);
// Check if n is not in dp then
// only call the function so as
// to reduce no of recursive calls
if (!dp.ContainsKey(n))
dp.Add(n, 1 + Math.Min(n % 2 + count(n / 2),
n % 3 + count(n / 3)));
// Return the answer
return dp[n];
}
// Driver Code
public static void Main(String[] args)
{
// Given number N
int N = 6;
// Function call
Console.WriteLine(String.Join("",
(count(N))));
}
}
// This code is contributed by Rajput-Ji
3
时间复杂度: O(log N)
辅助空间: O(1)