| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 476 人关注过本帖
标题:求助!串匹配问题!
取消只看楼主 加入收藏
giant
Rank: 1
等 级:新手上路
帖 子:180
专家分:0
注 册:2005-12-11
收藏
 问题点数:0 回复次数:1 
求助!串匹配问题!

下面的程序为什么会出现错误呢?那位能告诉我:谢谢

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#define MAX 30
typedef struct{
char *ch;
int length;
}HString;

HString InitStr(HString Q); //初始化函数
HString AssignStr(HString Q,char temp[MAX]); //拷贝函数
int Index(HString S,HString T); //模式匹配函数
HString ClearStr(HString Q); //清除函数

int main(void)
{
HString S,T;
char temp[MAX];

S=InitStr(S);
T=InitStr(T);
printf("Please input temp_S.ch:\n");
scanf("%s",temp);
S=AssignStr(S,temp);
printf("Please input temp_T.ch:\n");
scanf("%s",temp);
T=AssignStr(T,temp);
if(Index(S,T))
printf("success.\n");
else
printf("failure.\n");
S=ClearStr(S);
T=ClearStr(T);

return 0;
}

HString InitStr(HString Q)
{
Q.ch=NULL;
Q.length=0;

return Q;
}

HString AssignStr(HString Q,char temp[MAX])
{
int len;

if(Q.ch)
Q=ClearStr(Q);
len=strlen(temp);
if((Q.ch=(char *)malloc(len * sizeof(char)))==NULL)
{
exit(1);
}
strcpy(Q.ch,temp);
Q.length=len;

return Q;
}

int Index(HString S,HString T)
{
int i,j;

i=0; j=0;
while(i<=S.length-1 && j<=T.length-1)
{
if(S.ch[i]==T.ch[j])
{
i++;
j++;
}
else
{
i=i-j+1;
j=0;
}
}
if(j>=T.length)
return 1;
else
return 0;
}

HString ClearStr(HString Q)
{
if(Q.ch)
{
free(Q.ch);
Q.ch=NULL;
}
Q.length=0;

return Q;
}

搜索更多相关主题的帖子: include 
2006-03-27 22:04
giant
Rank: 1
等 级:新手上路
帖 子:180
专家分:0
注 册:2005-12-11
收藏
得分:0 
没人帮我吗?

2006-03-27 22:57
快速回复:求助!串匹配问题!
数据加载中...
 
   



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

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