阅读 210

使用 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 和其他语言。我们希望这篇文章对您有所帮助。


文章分类
百科问答
版权声明:本站是系统测试站点,无实际运营。本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 XXXXXXo@163.com 举报,一经查实,本站将立刻删除。
相关推荐