检查在C ++中是否可以将大数分为相等总和的两个或多个段
在这里,我们将看到一个程序,该程序可以检查一个数字是否可以分为多个相等相等的段。假设一个数字为74325,则可以将其分为三部分(7),(4、3),(2、5),所有部分的um值相同。
我们必须按照以下步骤解决此问题。
以数字为字符串
使用数组保存数组的前缀和
现在从第二个元素遍历到最后一个元素,并且第一段将从0到i-1,其总和将位于prefix_sum[i-1]
使用另一个从1遍历到n遍历的变量,然后继续将总和相加。
如果在任何阶段,总和值都与prefix_sum[i–1]相同,则该段的总和等于第一个。
将段总和值重新初始化为0,然后继续移动指针。
如果在任何阶段分段总和大于prefix_sum[i–1],则中断循环
如果我们到达最后一个目的地,并且如果最后一个分段总和与第一个分段总和相同,则可以将其划分为相等总和的分段。
示例
#include <iostream>
using namespace std;
bool canBeSegmented(string str) {
int n = str.length();
int prefix_sum[n];
prefix_sum[0] = str[0] - '0';
for (int i = 1; i < n; i++) {
prefix_sum[i] = prefix_sum[i - 1] + (str[i] - '0');
}
for (int i = 1; i <= n - 1; i++) {
int sum = prefix_sum[i - 1];
int prev_sum = 0;
int it = i;
bool flag = false;
while (it < n) {
prev_sum += str[it] - '0';
if (prev_sum == sum) {
prev_sum = 0;
flag = true;
} else if (prev_sum > sum) {
break;
}
it++;
}
if (prev_sum == 0 && it == n && flag) {
return true;
}
}
return false;
}
int main() {
string s = "74325";
if (canBeSegmented(s))
cout << "Yes, This can be segmented into more than two segments";
else
cout << "No, This can not be segmented into more than two segments";
}输出结果
Yes, This can be segmented into more than two segments
热门推荐
10 香港老妈结婚祝福语简短
11 毕业立体贺卡祝福语简短
12 简短新年年会祝福语
13 评论小品祝福语大全简短
14 恭喜师兄结婚祝福语简短
15 员工集体辞职祝福语简短
16 高中新生祝福语 简短
17 装修祝福语男生搞笑简短
18 生日开业蛋糕祝福语简短