要写一个文本文件的单词的计数和单词检索的c程序 我搞了很久都出错 那位高手会的指导小弟一下哦 ! 谢了!!

germ_da 2008-06-17 09:17:20
要写一个文本文件的单词的计数和单词检索的c程序 我搞了很久都出错 那位高手会的指导小弟一下哦 ! 谢了!!
...全文
177 9 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
yanxiangtianji 2008-06-17
  • 打赏
  • 举报
回复
匆匆写的 没有调试 但是应该没有什么大问题 要是有什么细节问题 你多包含

#include <stdio.h>
#define TOTAL 100000 //暂以100000为你文件中词数的最大值
#define SIZE 25 //暂以25为你文件中单个词的长度最大值(含结束符)

char word[TOTAL][SIZE];
int jishu[TOTAL]={1},total=0;

int compare(char *a,char *b)//same return 1;
{
int i;
for(i=0;a[i]!=0&&b[i]!=0;i++)
{
if(a[i]!=b[i])return 0;
}
if(a[i]==0&&b[i]==0)return 1;
return 0;
}
void check(char* a)
{
int i;
for(i=0;i<total;i++)
if(compare(word[i],a)==1)
{
jishu[i]++;
return;
}
for(i=0;a[i]!=0;i++)
{
word[total][i]=a[i];
}
word[total][i]='\0';
total++;
}
void search(char *a)
{
int i;
for(i=0;i<total;i++)
{
if(compare(a,word[i])==1)
printf("%s has been input %d time(s).\n",a,jishu[i]);
return;
}
printf("Can't find %s.\n",a);
}
int main()
{
FILE *fp;
char c,buf[SIZE];
int count=0;
fp=fopen("添你的文件名","r");
c=fgetc(fp);
while(c==' '||c=='\n')
{
c=fgetc(fp);
}//去除文件开头的空格与回车
while(c!=EOF)
{
if(c==' '||c=='\n')//认为文件中只有空格与回车两种非字母的字符
{
buf[count]='\0';
check(buf);
count=0;
}
else
{
buf[count]=c;
count++;
}
c=fgetc(fp);
}
if(count!=0)//最后一个单词结束后没有空格或回车,而是直接结束文件
{
buf[count]='\0';
check(buf);
}
fclose(fp);
//完成单词输入 计数与索引表建立
//你的问题规模不大(只有一个文件),我认为不用排序建立有效表,按输入顺序即可以了
printf("请输入您要查找的单词。\n");
while(scanf("%s\n",buf)!=EOF)//CTRL+Z即可(C的这个细节我没学,这里我是直接套C++的,要是不多请高手指出)
{
search(buf);
printf("请输入您要查找的单词。\n");
}
}

chwhaiwei 2008-06-17
  • 打赏
  • 举报
回复
单词计数要分汉字和英词,查找用全文检索算法(网上应该很多)
HelloDan 2008-06-17
  • 打赏
  • 举报
回复
C++ primer里面倒是有一个这样的例子。
xkyx_cn 2008-06-17
  • 打赏
  • 举报
回复
请把你的程序贴出来,让大家帮你改错
lycdx 2008-06-17
  • 打赏
  • 举报
回复
刚才我试了一下,上面的代码好象有问题啊!!
mwx285 2008-06-17
  • 打赏
  • 举报
回复
错了就改么!!
代码??
长安宁 2008-06-17
  • 打赏
  • 举报
回复

#include <stdio.h>
#define N 3


int main()
{
char arr[N][50];
char find[10];
int i,count=0;
char *mp,*sp;

for(i=0;i<N;i++)
{
scanf("%s",arr[i]);
}

scanf("%s",find);


for(i=0;i<N;i++)
{
sp = find;
mp = arr[i];

while(*mp)
{
if(*mp==*sp)
{
while(*sp&&(*++mp==*++sp)); //每次都要比一次 sp 后边的NULL;
if(!*sp)
{
count++;
}

sp=find;
mp--; //所以要退回来一个字节
}
mp++;
}

/**/
}

printf("count=%d\n",count);
return 0;
}

刚写了一例,看看
yuyunliuhen 2008-06-17
  • 打赏
  • 举报
回复
啥错?
homesos 2008-06-17
  • 打赏
  • 举报
回复
如果编译出错 注意看编译提示
如果程序结果出错 设置断点跟踪一下看看 运行中的值是不是跟自己预想的一样 如果不一样 就有可能逻辑出了问题

33,321

社区成员

发帖
与我相关
我的任务
社区描述
C/C++ 新手乐园
社区管理员
  • 新手乐园社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧