没有合适的资源?快使用搜索试试~ 我知道了~
浙江工业大学算法实验2 动态规划算法实现.docx
1.该资源内容由用户上传,如若侵权请联系客服进行举报
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
版权申诉
0 下载量 10 浏览量
2022-06-05
11:21:32
上传
评论
收藏 101KB DOCX 举报
温馨提示
试读
15页
。。。
资源推荐
资源详情
资源评论
实验 2 动态规划算法实现
一、实验目标:
1.熟悉动态规划算法实现的基本方法和步骤;
2. 学会动态规划算法的实现方法和分析方法:
二、实验内容:
问题 1:最长公共子序列的问题,测试数据
X={ABCBDAB} Y={BDCABA}
X={zhejiang university of technology} Y= {zhejiang
university city college}
1-1 实验代码及截图
#include<iostream>
#include<cstring>
using namespace std;
//求得两个字符串的最大公共子序列长度
int LCSLength(int m, int n,char* x, char* y,int **c, int **b)
{
int i, j, len;
//i=0 || j=0
for (i = 0; i < m + 1; i++) c[i][0] = 0;
for (j = 0; j < n + 1; j++) c[0][j] = 0;
//i,j>0
for (i = 1; i <= m; i++)
{
for (j = 1; j <= n; j++)
{
if (x[i] == y[j])//if (x[i - 1] == y[j - 1])
{
c[i][j] = c[i - 1][j - 1] + 1;
b[i][j] = 1;
}
else if (c[i - 1][j] >= c[i][j - 1])
{
c[i][j] = c[i - 1][j];
b[i][j] = 2;
}
else
{
c[i][j] = c[i][j - 1];
b[i][j] = 3;
}
}
}
len = c[m][n];
return len;
}
//构造最长公共子序列
void LCS(int i, int j, char *x, int **b)
{
if (i == 0 || j == 0) return;
if (b[i][j] == 1)
{
LCS(i - 1, j - 1, x, b);
cout << x[i - 1];//c[i][]对应 str1 的第 i-1 个元素
}
else if (b[i][j] == 2)
{
LCS(i - 1, j, x, b);
}
else
{
LCS(i, j - 1, x, b);
}
}
int main(){
char str1[1000], str2[1000];
int i, m, n, len;
cout << "请输入第一个字符串:";
gets_s(str1);
cout << "请输入第二个字符串:";
gets_s(str2);
m = strlen(str1);
n = strlen(str2);
int **c = new int*[m + 1]; / /行
for (i = 0; i < m + 1; i++)
c[i] = new int[n + 1];//列
int **b = new int*[m + 1];
for (i = 0; i < m + 1; i++)
b[i] = new int[n + 1];
len = LCSLength(m, n, str1, str2, c, b);
cout << "最长公共子序列的长度为:" << len << endl;
cout << ("最长公共子序列为:");
LCS(m, n, str1, b);
cout << endl;
system("pause");
return 0;
}
实验截图:
剩余14页未读,继续阅读
资源评论
apple_51426592
- 粉丝: 9623
- 资源: 9658
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功