33,311
社区成员
发帖
与我相关
我的任务
分享
#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");
}
}
#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;
}