输入一段英文,再输入一个单词,查找该单词在该段英文中出现的次数以及位置,位置信息保存在一个数组中。急 25

急求啊!用串做啊!拜托了!... 急求啊!用串做啊!拜托了! 展开
 我来答
江伟77
2012-06-27 · TA获得超过591个赞
知道小有建树答主
回答量:230
采纳率:100%
帮助的人:209万
展开全部
看上去有点长,做了一些修饰性的东西。
#include <stdio.h>
#include <string.h>
#include <ctype.h>
#define M 100
#define N 10
#define T 10
int main(void)
{
int a[T]={0};
int i,j=0,k=0,num=0,word=0;
char str[M],str1[N],str2[N],*p;
printf("输入一行英文:\n");
gets(str);
printf("输入一个单词:\n");
gets(str1);
p=str;
while(!isalpha(*p)) p++; //去掉句子前的其他字符
for(i=0;*(p+i)!='\0';i++)
if(isalpha(*(p+i)))
{
if(word==0)
{
word=1;
num++;
}
str2[j++]=*(p+i);
}
else
{
word=0;
str2[j]='\0';
if(strcmp(str1,str2)==0) a[k++]=num;
j=0;
}
str2[j]='\0';
if(strcmp(str1,str2)==0) a[k++]=num; //处理句子最后一个单词
printf("结果:\n");
printf("这句共有单词%d个\n",num);
if(k==0)
printf("句子中没有单词%s\n",str1);
else
{
printf("所查单词位置:\n");
for(i=0;i<k;i++)
printf("%3d",a[i]);
}
getchar();
}

显示样式:
输入一行英文:
i am a boy.he is a boy.
输入一个单词:
boy
结果:
这句共有单词8个
所查单词位置:
4 8
追问
不需要一共有多少个单词,需要的是这个查找的单词出现了几次,以及出现的位置,而且要一段英文,不是一行的,能改下么?谢谢了!急啊。。。
追答
#include 
#include
#include
#define M 1000 //一段英文的话,改M,一个串长较大的字符串嘛,1000不够再加大啊#define N 10
#define T M/N //此处改一下,
int main(void)
{
int a[T]={0};
int i,j=0,k=0,num=0,word=0;
char str[M],str1[N],str2[N],*p;
printf("输入一段英文:\n"); // 以回车结束,中间不能有回车啊
gets(str);
printf("输入一个单词:\n");
gets(str1);
p=str;
while(!isalpha(*p)) p++; //去掉句子前的其他字符
for(i=0;*(p+i)!='\0';i++)
if(isalpha(*(p+i)))
{
if(word==0)
{
word=1;
num++;
}
str2[j++]=*(p+i);
}
else
{
word=0;
str2[j]='\0';
if(strcmp(str1,str2)==0) a[k++]=num;
j=0;
}
str2[j]='\0';
if(strcmp(str1,str2)==0) a[k++]=num; //处理句子最后一个单词
printf("结果:\n");
if(k==0)
printf("没有查到单词%s\n",str1);
else
{
printf("这个单词共出现%d次\n",k); //此处改了
printf("所查单词位置:\n");
for(i=0;i<k;i++)
printf("%3d",a[i]); //单词位置存在数组a[]中
}
getchar();
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
沧海雄风2009
2012-06-27 · TA获得超过1.1万个赞
知道大有可为答主
回答量:8525
采纳率:79%
帮助的人:2869万
展开全部
第1次,下标4第1次,下标14第1次,下标28
Press any key to continue

#include <stdio.h>
main()
{
int i,add=0,position[20]={0};
char str[]="are you a dog you are a pig you are everything";
for (i=0;str[i]!='0';i++)
{
if (str[i]=='y' && str[i+1]=='o' && str[i+2]=='u' )
{
printf("第%d次,下标%d\n",add+1,i);
}
}
}
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式