给定一个数字字符串N和一个整数 K ,任务是将N 的数字拆分为子部分,以使可被K整除的段数最大化。
注意:我们可以在相邻数字对之间进行任意数量的垂直切割。
例子:
Input: N = 32, K = 4
Output: 1
Explanation:
32 is divisible by 4 but none if its digits are individually divisible, so we don’t perform any splits.
Input: N = 2050, K = 5
Output: 3
Explanation:
2050 can be split into 2, 0, 5, 0 where 0, 5, 0 are divisible by 5.
Input: N = 00001242, K = 3
Output: 6
Explanation:
00001242 can be split into 0, 0, 0, 0, 12, 42 where all the parts are divisible by 3.
方法:
为了解决上面提到的问题,我们将尝试使用递归方法。
- 检查当前字符和下一个字符之间是否存在垂直分区,如果没有,则我们再次对下一个索引执行递归并通过连接当前字符更新子字符串值。
- 现在,如果当前字符和下一个字符之间存在垂直分区,则存在两种情况:
- 如果当前 subStr 可被 X 整除,则我们加 1,因为当前 subStr 是可能答案的 1,然后为下一个索引递归并将 subStr 更新为空字符串。
- 如果当前的 subStr 不能被 X 整除,那么我们只需重复下一个索引并将 subStr 更新为空字符串。
- 最多返回上面提到的两种可能情况。
下面是上述逻辑的实现
C++
// C++ program to split the number N
// by maximizing the count
// of subparts divisible by K
#include
using namespace std;
// Function to count the subparts
int count(string N, int X,
string subStr,
int index, int n)
{
if (index == n)
return 0;
// Total subStr till now
string a = subStr + N[index];
// b marks the subString uptil now
// is divisible by X or not,
// If it can be divided,
// then this substring is one
// of the possible answer
int b = 0;
// Convert string to long long and
// check if its divisible with X
if (stoll(a) % X == 0)
b = 1;
// Consider there is no vertical
// cut between this index and the
// next one, hence take total
// carrying total substr a.
int m1 = count(N, X, a, index + 1, n);
// If there is vertical
// cut between this index
// and next one, then we
// start again with subStr as ""
// and add b for the count
// of subStr upto now
int m2 = b + count(N, X, "",
index + 1, n);
// Return max of both the cases
return max(m1, m2);
}
// Driver code
int main()
{
string N = "00001242";
int K = 3;
int l = N.length();
cout << count(N, K, "", 0, l)
<< endl;
return 0;
}
Java
// Java program to split the number N
// by maximizing the count
// of subparts divisible by K
class GFG{
// Function to count the subparts
static int count(String N, int X,
String subStr,
int index, int n)
{
if (index == n)
return 0;
// Total subStr till now
String a = subStr + N.charAt(index);
// b marks the subString uptil now
// is divisible by X or not,
// If it can be divided,
// then this subString is one
// of the possible answer
int b = 0;
// Convert String to long and
// check if its divisible with X
if (Long.valueOf(a) % X == 0)
b = 1;
// Consider there is no vertical
// cut between this index and the
// next one, hence take total
// carrying total substr a.
int m1 = count(N, X, a, index + 1, n);
// If there is vertical
// cut between this index
// and next one, then we
// start again with subStr as ""
// and add b for the count
// of subStr upto now
int m2 = b + count(N, X, "",
index + 1, n);
// Return max of both the cases
return Math.max(m1, m2);
}
// Driver code
public static void main(String[] args)
{
String N = "00001242";
int K = 3;
int l = N.length();
System.out.print(count(N, K, "", 0, l) + "\n");
}
}
// This code is contributed by Rajput-Ji
Python3
# Python3 program to split the number N
# by maximizing the count
# of subparts divisible by K
# Function to count the subparts
def count(N, X, subStr, index, n):
if (index == n):
return 0
# Total subStr till now
a = subStr + N[index]
# b marks the subString uptil now
# is divisible by X or not,
# If it can be divided,
# then this substring is one
# of the possible answer
b = 0
# Convert string to long long and
# check if its divisible with X
if (int(a) % X == 0):
b = 1
# Consider there is no vertical
# cut between this index and the
# next one, hence take total
# carrying total substr a.
m1 = count(N, X, a, index + 1, n)
# If there is vertical
# cut between this index
# and next one, then we
# start again with subStr as ""
# and add b for the count
# of subStr upto now
m2 = b + count(N, X, "", index + 1, n)
# Return max of both the cases
return max(m1, m2)
# Driver code
N = "00001242"
K = 3
l = len(N)
print(count(N, K, "", 0, l))
# This code is contributed by sanjoy_62
C#
// C# program to split the number N
// by maximizing the count
// of subparts divisible by K
using System;
class GFG{
// Function to count the subparts
static int count(String N, int X,
String subStr,
int index, int n)
{
if (index == n)
return 0;
// Total subStr till now
String a = subStr + N[index];
// b marks the subString uptil now
// is divisible by X or not,
// If it can be divided,
// then this subString is one
// of the possible answer
int b = 0;
// Convert String to long and
// check if its divisible with X
if (long. Parse(a) % X == 0)
b = 1;
// Consider there is no vertical
// cut between this index and the
// next one, hence take total
// carrying total substr a.
int m1 = count(N, X, a, index + 1, n);
// If there is vertical
// cut between this index
// and next one, then we
// start again with subStr as ""
// and add b for the count
// of subStr upto now
int m2 = b + count(N, X, "",
index + 1, n);
// Return max of both the cases
return Math.Max(m1, m2);
}
// Driver code
public static void Main(String[] args)
{
String N = "00001242";
int K = 3;
int l = N.Length;
Console.Write(count(N, K, "", 0, l) + "\n");
}
}
// This code is contributed by Rajput-Ji
Javascript
输出:
6