思路:dp+记忆化搜索,设dp[n][m]表示s1与s2不同字符个数为n,还需要变m步的方法数,那么:

dp[n][m]  = (c[n][i]*c[N-n][K-i]) * dp[n-i+(K-i)][m-1]  (i需满足数组下标不小0)。c数组表示组合数。

#include<cstdio>
#include<string>
#include<cstring>
#include<iostream>
#include<algorithm>
#define MOD 1000000009
const int MAXN = 101;
using namespace std;
long long int dp[MAXN][MAXN], c[MAXN][MAXN], N, M, K;
void init(){
c[0][0] = 1, c[1][0] = 1, c[1][1] = 1;
for(int i = 2; i < MAXN; i ++){
c[i][0] = 1;
for(int j = 1; j <= i; j ++){
c[i][j] = c[i-1][j-1] + c[i-1][j];
if(c[i][j] >= MOD) c[i][j] %= MOD;
}
}
}
int dfs(int n, int m){
if(dp[n][m] != -1) return dp[n][m];
if(m == 0) return dp[n][m] = (n == 0);
dp[n][m] = 0;
for(int i = 0; i <= K; i ++){
if(n < i || N - n < K - i) continue;
dp[n][m] += (((c[n][i] * c[N-n][K-i]) % MOD) * dfs(n - i + (K - i), m-1))%MOD;
dp[n][m] %= MOD;
}
return dp[n][m];
}
int main(){
string s1, s2;
init();
while(cin >> N >> M >> K){
cin >> s1 >> s2;
int cnt = 0;
for(int i = 0; i < N; i ++)
if(s1[i] != s2[i]) cnt ++;
memset(dp, -1, sizeof dp);
printf("%d\n", dfs(cnt, M));
}
return 0;
}



最新文章

  1. Oracle SQL性能优化
  2. (转载)spring mvc DispatcherServlet详解之一---处理请求深入解析
  3. 正则表达式 exec 获取字符串中的汉字
  4. MVC概念性的内容
  5. 《转》.NET开源核心运行时,且行且珍惜
  6. 基于jquery打造的网页右侧自动收缩浮动在线客服代码
  7. Java [Leetcode 171]Excel Sheet Column Number
  8. Android之Http网络编程(三)
  9. OpenOffice 服务开机启动
  10. Sonar入门学习
  11. jsp中的jquery失效以及引入js失败的问题
  12. hdu 4407 Sum 容斥+当前离线
  13. sql连接查询 2011-10-10 23:13 (QQ空间)
  14. Liferay的架构:缓存(第一部分)
  15. ecshop中ajax的调用原理 1
  16. wemall app商城源码中基于PHP的通用的树型类代码
  17. bzoj5100 [POI2018]Plan metra 构造
  18. Python爬虫之正则表达式(1)
  19. jmeter学习记录--08--第三方测试组件
  20. HAOI(十二省联考)2019 qwq记

热门文章

  1. Javascript中的迭代、归并方法
  2. sql System.Data.SqlClient.SqlError: 无法覆盖文件 &#39;C:\Program Files\Microsoft SQL Server\MSSQL\data\itsm_Data.MDF&#39;。数据库 &#39;my1&#39; 正在使用该文件的解决方案
  3. js 数字,金额 用逗号 隔开。数字格式化
  4. PHP之session_start()详解
  5. LBS地理位置距离计算方法之geohash算法
  6. 用PLSQL Developer粘贴数据的时候报oracle variant conversion error for variable v0
  7. node.js 1Million concurrent connections!
  8. 告诉你KVC的一切-b
  9. Automotive Security的一些资料和心得(2):Cryptography
  10. [XJOI NOI2015模拟题13] A 神奇的矩阵 【分块】