标题:[求助]动态规划
只看楼主
fengzar1984
Rank: 1
等 级:新手上路
帖 子:19
专家分:0
注 册:2006-3-30
 问题点数:0 回复次数:7 
[求助]动态规划

今天看见一帖求最长公共子序列的问题,后试着写了以下.

#include <stdio.h>
#include <string.h>
#define N 100
int lcslength(char a[], char b[], int c[N][N]);
char *lcs(char str[], char a[], char b[]);
int c[N][N];
char str[N];
int lcslength(char a[], char b[], int c[N][N])
{
int i, j, sa , sb;
sa = strlen(a);
sb = strlen(b);
for (i = 0; i < sa; i++)
c[i][0] = 0;
for (j = 0; j < sb; j++)
c[0][j] = 0;
for(i = 1; i < sa; i++ )
for( j = 1; j < sb; j++)
{
if(a[i-1] == b[j-1])
{
c[i][j] = c[i-1][j-1] + 1;
}
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[sa][sb];
}

char *lcs(char str[], char a[], char b[])
{
int i, j;
int k;
i = strlen(a);
j = strlen(b);
k = lcslength(a,b,c);
str[k] = '\0';
while(k >= 0)
{
if(c[i][j] == c[i-1][j]) i--;
if(c[i][j] == c[i][j-1]) j--;
else
{
str[--k] = a[i-1];
i--;
j--;
}
}
return str; //str 怎么没有值啊!总是指向空串?
}


int main()
{
char a[N], b[N];
printf("input the first array:\n");
gets(a);
printf("input the second array:\n");
gets(b);
printf("the lcs:\n");
puts(lcs(str, a, b));
return 0;
}

str 怎么没有值啊!总是指向空串?


搜索更多相关主题的帖子: 动态规划 include int string 
2007-01-13 14:18
zouchao
Rank: 1
等 级:新手上路
帖 子:50
专家分:0
注 册:2006-12-14
得分:0 

把题写清楚点~~~

2007-01-13 16:50
卧龙孔明
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:59
帖 子:3872
专家分:684
注 册:2006-10-13
得分:0 

以前我发过一个,其中包括了你问的问题,详细请见http://bbs.bc-cn.net/viewthread.php?tid=109661&extra=&page=100#


My Blog: www.aiexp.info
虽然我的路是从这里开始的,但是这里不再是乐土.感谢曾经影响过,引导过,帮助过我的董凯,飞燕,leeco,starwing,Rockcarry,soft_wind等等等等.别了,BCCN.
2007-01-13 18:08
fengzar1984
Rank: 1
等 级:新手上路
帖 子:19
专家分:0
注 册:2006-3-30
得分:0 
[QUOTE]最长公共子序列[/QUOTE]
2007-01-14 08:01
fengzar1984
Rank: 1
等 级:新手上路
帖 子:19
专家分:0
注 册:2006-3-30
得分:0 

感谢你的资料,我要具体的解决方案.

2007-01-14 11:26
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
得分:0 
int c[1000][1000];
void LCSLength(char *s,char *t,int lens,int lent)
{
int i,j;
for(i=1;i<lens;i++)
{
c[i][0]=0;
}
for(i=1;i<lent;i++)
{
c[0][i]=0;
}
for(i=1;i<=lens;i++)
{
for(j=1;j<=lent;j++)
{
if(s[i]==t[j])
{
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];
}
}
}
}
}

倚天照海花无数,流水高山心自知。
2007-01-14 19:09
fengzar1984
Rank: 1
等 级:新手上路
帖 子:19
专家分:0
注 册:2006-3-30
得分:0 
楼上正解.
谢谢楼上的,是正确的.
我搞定了.
2007-01-17 13:23
lzz4438253
Rank: 1
等 级:新手上路
帖 子:109
专家分:0
注 册:2007-1-4
得分:0 
  那么大的数组啊...

2007-01-17 13:30



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-115770-1-1.html




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

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