| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 990 人关注过本帖
标题:[原创] 求最长子序列的源程序问题(问题已经解决!)
只看楼主 加入收藏
youpenglao
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2005-12-28
收藏
 问题点数:0 回复次数:2 
[原创] 求最长子序列的源程序问题(问题已经解决!)

源程序如下:

#include <iostream.h>
#include <string.h>
#define N 100
char a[N],b[N],str[N];

int lcs_len(char *a, char *b, int c[N][N])
{
int m=strlen(a), n=strlen(b), i,j;
for (i=0;i<=m;i++) c[i][0]=0;
for (i=0;i<=n;i++) c[0][i]=0;
for (i=1;i<=m;i++)
for (j=1;j<=m;j++)
if (a[i-1]==b[j-1])
c[i][j]=c[i-1][j-1]+1;
else if (c[i-1][j]>=c[i][j-1])
c[i][j]=c[i-1][j];
else
c[i][j]=c[i][j-1];
return c[m][n];
}

char *buile_lcs(char s[],char *a, char *b)
{
int k, i=strlen(a), j=strlen(b), int c[N][N];
k=lcs_len(a,b,c);
s[k]='\0';
while (k>0)
if (c[i][j]==c[i-1][j]) i--;
else if (c[i][j]==c[i][j-1]) j--;
else
{
s[--k]=a[i-1];
i--; j--;
}
return s;
}

void main()
{
char *p1,*p2;
p1=a;p2=b;
cout<<"Enter two string <"<<N <<"!"<<endl;
cin>>a>>b;
cout<<buile_lcs(str,p1,p2)<<endl;
}


在Microsoft Visual Studio 6.0环境下能通过编译,但是存在警告

--------------------Configuration: chj_5 - Win32 Debug--------------------
Compiling...
5.cpp
E:\Program Files\Microsoft Visual Studio\MyProjects\chj_5\5.cpp(24) : warning C4518: 'int ' : storage-class or type specifier(s) unexpected here; ignored
E:\Program Files\Microsoft Visual Studio\MyProjects\chj_5\5.cpp(24) : warning C4228: nonstandard extension used : qualifiers after comma in declarator list are ignored
Linking...

chj_5.exe - 0 error(s), 2 warning(s)

继续运行,在数组长度较短的情况下可以正常得出结果,但是数组长度较大时就出现如下情况:

图片附件: 游客没有浏览图片的权限,请 登录注册

图片附件: 游客没有浏览图片的权限,请 登录注册

各位达人帮帮忙````指导指导``不胜感激!!


[此贴子已经被作者于2005-12-28 17:51:22编辑过]

搜索更多相关主题的帖子: 源程序 序列 长子 char int 
2005-12-28 14:29
C++大粉丝
Rank: 4
等 级:贵宾
威 望:10
帖 子:477
专家分:0
注 册:2004-4-23
收藏
得分:0 
F5 调试运行
F10 F11

自己调试~

I am a big fan of c plus plus.
2005-12-28 15:44
youpenglao
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2005-12-28
收藏
得分:0 

已经调试了`~`

结果显示这个错误

图片附件: 游客没有浏览图片的权限,请 登录注册


我是初学C++的,知道这样老是问人不怎么好..

但是在自己实在已无能为力的情况选择象别人请教,我想是应该的


话虽说:程序是自己调试出来的,但是这个程序我在长度比较短的数组上是能成功运行,并且得到正确大答案,可是在数组长度增加到一定时,就会提示错误,百思不得其解,如果没人帮忙就还是自己慢慢的做吧

祝各位在论坛能学到真正的知识!

2005-12-28 16:55
快速回复:[原创] 求最长子序列的源程序问题(问题已经解决!)
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016459 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved