无法在C++中为SAFECRAC SPOJ正确使用MODULO操作
Unable to use MODULO operation correctly in C++ for SAFECRAC SPOJ?
我正在努力解决问题http://www.spoj.com/problems/SAFECRAC.
我认为使用动态编程可以很容易地解决这个问题,但由于最终答案非常大,我们必须输出答案MODULO 1000000007。我似乎无法正确使用MODULO操作,因为我得到了长度为3的正确输出,但长度为25的输出与样本不同。
这是我的代码:
#include <iostream>
using namespace std;
#define MOD 1000000007
typedef long long int ll;
ll dp[100001][10];
int t, n;
void precompute()
{
for (int j = 0; j < 10; j++)
dp[1][j] = 1;
for (int i = 2; i <= 100000; i++) {
for (int j = 0; j < 10; j++) {
if (j == 0) dp[i][j] = dp[i-1][7] % MOD;
if (j == 1) dp[i][j] = ( dp[i-1][2] + dp[i-1][4] ) % MOD;
if (j == 2) dp[i][j] = ( dp[i-1][1] + ( dp[i-1][3] + dp[i-1][5] ) % MOD ) % MOD;
if (j == 3) dp[i][j] = ( dp[i-1][2] + dp[i-1][6] ) % MOD;
if (j == 4) dp[i][j] = ( dp[i-1][1] + ( dp[i-1][5] + dp[i-1][7] ) % MOD ) % MOD;
if (j == 5) dp[i][j] = ( ( dp[i-1][2] + dp[i-1][4] ) % MOD + ( dp[i-1][6] + dp[i-1][8] ) % MOD ) % MOD;
if (j == 6) dp[i][j] = ( dp[i-1][3] + ( dp[i-1][5] + dp[i-1][9] ) % MOD ) % MOD;
if (j == 7) dp[i][j] = ( dp[i-1][4] + ( dp[i-1][8] + dp[i-1][0] ) % MOD ) % MOD;
if (j == 8) dp[i][j] = ( dp[i-1][5] + ( dp[i-1][7] + dp[i-1][9] ) % MOD ) % MOD;
if (j == 9) dp[i][j] = ( dp[i-1][6] + dp[i-1][8] ) % MOD;
}
}
}
int main()
{
precompute();
cin >> t;
while (t--) {
cin >> n;
ll sum = 0;
for (int i = 0; i < 10; i++) {
sum += dp[n][i];
}
cout << sum << endl;
}
}
检查main()
中的for
循环。dp[n][i]
总是小于MOD
,但这对于sum
是不保证的。因此,请尝试将sum += dp[n][i];
更改为sum = (sum + dp[n][i]) % MOD;
。
相关文章:
- 为什么在popback()操作之后,它仍然打印完整的矢量
- 重载操作程序时出错>>用于类中的字符串 memebr
- 对字符串进行位操作
- 我可以在 C++ 中的函数体之外进行操作吗?
- MPI突然停止了对多个核心的操作
- 如何在信号处理程序和普通函数中对全局变量进行互斥读写操作
- 对字符数组中的元素执行逐位操作
- 如何在directx/c++中进行平移/缩放操作
- 逐位操作的隐式类型转换
- 为什么一个向量上的多线程操作很慢
- 排序时无法执行交换操作.我做的时候它会崩溃.为什么
- 位移操作和位掩码未检测到重复字符
- 如何进行特定的位操作?
- 当我们进行一些操作时,应该使用什么'std::string'或'std::stringstream'?
- 字符串操作 - 字符计数
- 此代码中的操作流程是什么?C/C++.
- 是``if`语句''在modulo之前和分配操作之前的冗余
- 使用Modulo操作的正确方法
- 无法在C++中为SAFECRAC SPOJ正确使用MODULO操作
- 高效的Modulo 3操作