在SPOJ INCSEQ -递增子序列中获取WA
Getting WA in SPOJ INCSEQ - Increasing Subsequences
我不知道为什么我在10号收到WA。我用了BIT和Combination。问题链接:SPOJ INCSEQ
问题详细说明:给定N(1≤N≤10,000)个整数序列S1,…, SN(0≤Si <100,000),计算长度为K的S的递增子序列个数(1≤K≤50,K≤N);即k元组的个数i1,…, iK使得1≤i1 <…& lt;iK≤N, Si1 <…& lt;好食。
这是我的代码
我认为nCr使用Mod函数有问题。他们没有给出失败的测试用例,所以我没有任何失败的测试用例。
// Here i compute nCk
unsigned long long combination(ll n,ll k)
{
unsigned long long ans=1;
k=k>n-k?n-k:k;
ll j=1;
for(; j<=k; j++,n--)
{
if(n%j==0)
{
ans*=n/j;
}
else if(ans%j==0)
{
ans=ans/j*n;
}
else
{
ans=(ans*n)/j;
}
}
return ans%mod;
}
请帮助
您的combination
方法是错误的,因为对于较大的数字,nCr的结果将大于long long
的范围。
因此,有效地使用模,我们可以避免在这种情况下的溢出
我们知道还有另一种方法来计算nCr
我们知道
nCr = (n - 1)C(r - 1) + (n - 1)Cr
由于k <= 50,且k <= 50很小,我们可以计算组合表c
如下:
int[][]c = new int[n + 1][k+1];
c[0][0] = 1;
for (int i = 1; i <= n; i++) {
c[i][0] = 1;
if(i <= k)
c[i][i] = 1;
for (int j = 1; j <= k; j++) {
c[i][j] = c[i - 1][j - 1] + c[i - 1][j];
c[i][j] %= mod;
}
}
mod操作将确保我们的结果永远不会溢出
相关文章:
- C++为构建时间获取QDateTime的可靠方法
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 如何使用 < 和 > 命令获取 c++ 中的输入和输出?
- 使用指针从C++中的数组中获取最大值
- 如何获取std::result_of函数的返回类型
- 如何在openssl-ecc中获取十六进制格式的私钥
- 使用Unreal C++获取VR耳机的世界位置/方向
- 获取日期异步信号安全吗?如果在信号处理程序中使用,它会导致死锁吗
- 从C字符串中获取奇怪的字符串长度
- 为什么我的for循环不能正确获取argv
- 从python中调用C++函数并获取返回值
- 如何获取一个数字的前3位
- 获取字符串的长度并将其分配给数组
- 无法获取菜单选择以运行函数.C++
- 数组长度,为什么从命令行获取时不能使用它?
- Boost Spirit,获取迭代器内部语义动作
- 尝试通过OCI例程从Oracle获取blob数据,但出现错误:ORA-01008:并非所有变量都绑定
- 具有默认值的引用获取函数
- xmake总是报告:错误:无法获取cxx的程序,为什么
- 在SPOJ INCSEQ -递增子序列中获取WA