使用 C++ 查找从二进制字符串的 1 开始的唯一排列的数量
在给定的问题中,我们得到一个由 0 和 1 组成的字符串;我们需要找到排列的总数,使字符串以 1 开头。由于答案可能是一个巨大的数字,因此我们将其打印为带有 1000000007 的 mod。
Input : str ="10101001001"Output : 210Input : str ="101110011"Output : 56
我们将通过应用一些组合数学并建立一些公式来解决给定的问题。
寻找解决方案的方法
在该方法中,我们将计算 0 和 1 的数量。现在让我们假设 n 是字符串中 1 的个数,m 是字符串中 0 的个数,L 是给定字符串的长度,所以我们用来解决这个问题的公式是 (L-1 )!/ (n-1)! *米!。
示例
#include <bits/stdc++.h>#define MOD 1000000007 // 将 1e9 + 7 定义为 MODusing namespace std;long long fact(long long n) { if(n <= 1) return 1; return ((n % MOD) * (fact(n-1) % MOD)) % MOD; }int main() { string s = "101110011"; long long L = s.size(); // 给定字符串的长度 long long count_1 = 0, count_0 = 0; // 保持 1 和 0 的计数 for(auto x : s) { if(x == '1') count_1++; // 1的频率 else count_0++; // 0 的频率 } if(count_1 == 0){ cout << "0\n"; // 如果字符串仅由 0 组成,那么我们的答案将为 0 } else { long long factL = fact(L-1); // (L-1)! long long factn = fact(count_1 - 1); // (n-1)! long long factm = fact(count_0); // 米! long long ans = factL / (factn * factm); // 把公式 cout << ans << "\n"; } return 0; }
输出结果
56
给定程序的时间复杂度为O(N),其中 n 是给定字符串的长度。
上面代码的解释
在这种方法中,我们现在计算字符串中存在的 1 和 0 的数量,我们在开头放置一个,然后在长度为 L-1 的字符串中制定所有可能的 0 和 1 排列,因此通过制定这个我们得到(L-1)的公式!/ (n-1)!*米!哪里(n-1)!是剩余 1 的排列,和 m!是 0 的排列。
结论
在本文中,我们解决了一个问题,即通过应用一些组合数学并为其编写公式,找到从二进制字符串的 1 开始的唯一排列的数量。
我们还学习了针对此问题的 C++ 程序以及解决此问题的完整方法 (Normal)。我们可以用其他语言编写相同的程序,例如 C、java、python 和其他语言。我们希望这篇文章对您有所帮助。