首页 考试吧论坛 Exam8视线 考试商城 网络课程 模拟考试 考友录 实用文档 求职招聘 论文下载
2011中考 | 2011高考 | 2012考研 | 考研培训 | 在职研 | 自学考试 | 成人高考 | 法律硕士 | MBA考试
MPA考试 | 中科院
四六级 | 职称英语 | 商务英语 | 公共英语 | 托福 | 雅思 | 专四专八 | 口译笔译 | 博思 | GRE GMAT
新概念英语 | 成人英语三级 | 申硕英语 | 攻硕英语 | 职称日语 | 日语学习 | 法语 | 德语 | 韩语
计算机等级考试 | 软件水平考试 | 职称计算机 | 微软认证 | 思科认证 | Oracle认证 | Linux认证
华为认证 | Java认证
公务员 | 报关员 | 银行从业资格 | 证券从业资格 | 期货从业资格 | 司法考试 | 法律顾问 | 导游资格
报检员 | 教师资格 | 社会工作者 | 外销员 | 国际商务师 | 跟单员 | 单证员 | 物流师 | 价格鉴证师
人力资源 | 管理咨询师考试 | 秘书资格 | 心理咨询师考试 | 出版专业资格 | 广告师职业水平
驾驶员 | 网络编辑
卫生资格 | 执业医师 | 执业药师 | 执业护士
会计从业资格考试会计证) | 经济师 | 会计职称 | 注册会计师 | 审计师 | 注册税务师
注册资产评估师 | 高级会计师 | ACCA | 统计师 | 精算师 | 理财规划师 | 国际内审师
一级建造师 | 二级建造师 | 造价工程师 | 造价员 | 咨询工程师 | 监理工程师 | 安全工程师
质量工程师 | 物业管理师 | 招标师 | 结构工程师 | 建筑师 | 房地产估价师 | 土地估价师 | 岩土师
设备监理师 | 房地产经纪人 | 投资项目管理师 | 土地登记代理人 | 环境影响评价师 | 环保工程师
城市规划师 | 公路监理师 | 公路造价师 | 安全评价师 | 电气工程师 | 注册测绘师 | 注册计量师
缤纷校园 | 实用文档 | 英语学习 | 作文大全 | 求职招聘 | 论文下载 | 访谈 | 游戏
您现在的位置: 考试吧(Exam8.com) > 计算机等级考试 > 计算机二级 > C加加 > 复习资料 > 正文

2010全国计算机等考二级C++:最长公共子序列

来源:考试吧Exam8.com) 2010-8-20 15:24:13 考试吧:中国教育培训第一门户 模拟考场
2010全国计算机等考二级C++:最长公共子序列。

  一、算法思想

  一个给定序列的子序列是在该序列中删去若干元素后得到的序列。给定两个序列X和Y,当另一序列Z既是X的子序列又是Y的子序列时,称Z是序列X 和Y的公共子序列。最长公共子序列就是求给定两个序列的一个最长公共子序列。动态规划可以有效的解决此问题。由最长公共子序列问题的子序列的最优子结构性质,可以建立子问题最优的递归关系。用c[i][j]记录序列Xi和Yi的最长公共子序列的长度,递归关系如下:

  0 i=0,j=0

  c[i][j]= c[i-1][j][j-1]+1 i,j> 0;xi==yj

  max c[i][j-1],c[i-1][j] I,j> 0;xi==yj

  在具体的算法设计中,以序列X= { x1,x2,x3,…,xm }和Y= {y1,y2,y3,…,ym}作为输入。输出三个数组c,b,temp。其中c[i][j]存储Xi和Yj的公共子序列的长度,b[i][j]记录c[i][j]的值是由哪一个子问题的解得到的,这在构造最长公共子序列时要用到。问题得最优解,即X和Y得最长公共子序列记录在temp[h]中。

  二、源代码

  下面是在Microsoft Visual C++ 6.0中编写的求最长公共子序列的源程序,程序定义了最大得字符串长度为99,是将p48页的动态规划算法改写而来的。

  #include

  #include

  #define MAX 99

  //typedef char MM;

  void main()

  { int i,j,m,n,h=0;

  char x[MAX]={ ' ', ' '},y[MAX]={ ' ', ' '},b[MAX][MAX]={ ' '};

  int c[MAX][MAX]={0};

  char temp[MAX]={ ' '};

  cout < < "**本程序可以求得字符数在99以内的任意两个字符串的最大公共子序列**\n ";

  cout < < "请输入第一个字符串的长度m= ";

  cin> > m;

  cout < < "请输入第一个字符串(“回车”结束)\n如果输入的字符数超过m,则会出错!\nx[ " <

  for(i=1;i <=m;i++)

  cin> > x[i]; //键盘输入x和y

  cout < < "请输入第二个字符串的长度n= ";

  cin> > n;

  cout < < "请输入第二个字符串\ny[ " <

  for(i=1;i <=n;i++)

  cin> > y[i];

  for(i=1;i <=m;i++)c[i][0]=0; //动态规划开始

  for(i=1;i <=n;i++)c[0][i]=0;

  for(i=1;i <=m;i++)

  for(j=1;j <=n;j++)

  {if(x[i]==y[j])

  {c[i][j]=c[i-1][j-1]+1;

  b[i][j]= '\\ ';

  }else

  if(c[i-1][j]> =c[i][j-1])

  { c[i][j]=c[i-1][j];

  b[i][j]= '│ ';

  }else{c[i][j]=c[i][j-1];

  b[i][j]= '- ';

  }

  } //动态规划结束

  cout < < "c[m][n]中的内容:\n ";

  for(i=0;i <=m;i++)

  {for(j=0;j <=n;j++)

  cout <

  cout <

  }

  cout < < "b[m][n]中的内容:\n ";

  for(i=1;i <=m;i++)

  {for(j=1;j <=n;j++)

  cout <

  cout <

  }

1 2 3 下一页
  相关推荐:2010年9月计算机等级考试精华备考资料汇总
       计算机等级考试二级VB上机试题及答案汇总
       计算机等级考试二级VB模拟试题及答案汇总
文章搜索
版权声明:如果计算机等级考试网所转载内容不慎侵犯了您的权益,请与我们联系800@exam8.com,我们将会及时处理。如转载本计算机等级考试网内容,请注明出处。