【C语言】求串中最长单词极其长度
题目:编写一个函数maxword,输出s指向的串中最长的单词及长度,格式如下:voidmaxword(char*s)例如,char*s=”Iamastudent,Shei...
题目:编写一个函数maxword,输出s指向的串中最长的单词及长度,格式如下:
void maxword(char * s )
例如,char*s=”I am a student,She is a physician”; s 所指的串中最长的单词为physician,长度为9。
#include<stdio.h>
void maxword(char *s)
{
int i,j,t=0,max=0;
for(i=0;s[i]!='\0';i++)
{
if((s[i]>='a'&&s[i]<='z')||(s[i]>='A'&&s[i]<='Z'))
{
t++;
}
else if(t>max)
{
max=t;
t=0;
j=i;
}
}
if(t>max)
max=t;
printf("最长单词字母个数为%d\n",max);
for(i=j-max;i<j;i++)
printf("%c",s[i]);
printf("\n");
}
main()
{
char *s="I am a student.She is a physician";
void maxword(char *s);
maxword(s);
}
运行结果是:
最长单词字母个数为15
I am a student
求大神指点! 展开
void maxword(char * s )
例如,char*s=”I am a student,She is a physician”; s 所指的串中最长的单词为physician,长度为9。
#include<stdio.h>
void maxword(char *s)
{
int i,j,t=0,max=0;
for(i=0;s[i]!='\0';i++)
{
if((s[i]>='a'&&s[i]<='z')||(s[i]>='A'&&s[i]<='Z'))
{
t++;
}
else if(t>max)
{
max=t;
t=0;
j=i;
}
}
if(t>max)
max=t;
printf("最长单词字母个数为%d\n",max);
for(i=j-max;i<j;i++)
printf("%c",s[i]);
printf("\n");
}
main()
{
char *s="I am a student.She is a physician";
void maxword(char *s);
maxword(s);
}
运行结果是:
最长单词字母个数为15
I am a student
求大神指点! 展开
2个回答
展开全部
#include<stdio.h>
void maxword(char *s)
{
int i,t=0,max=0;
char a[10];
for(i=0;s[i]!='\0';i++)
{
if((s[i]>='a'&&s[i]<='z')||(s[i]>='A'&&s[i]<='Z'))
{
t++;
a[t]=s[i];
}
else if(*(s+i)==' '||*(s+i)=='.')
{
t=(t>max)?max:t ;
t = 0 ;
continue ;
}
}
printf("最长单词字母个数为%d\n",t);
for(i=1;i<10;i++)
{
printf("%c",a[i]);
}
}
main()
{
char *s="I am a student.She is a physician";
void maxword(char *s);
maxword(s);
}
尽量在不更改你原有的程序上,做出了一些更改。
void maxword(char *s)
{
int i,t=0,max=0;
char a[10];
for(i=0;s[i]!='\0';i++)
{
if((s[i]>='a'&&s[i]<='z')||(s[i]>='A'&&s[i]<='Z'))
{
t++;
a[t]=s[i];
}
else if(*(s+i)==' '||*(s+i)=='.')
{
t=(t>max)?max:t ;
t = 0 ;
continue ;
}
}
printf("最长单词字母个数为%d\n",t);
for(i=1;i<10;i++)
{
printf("%c",a[i]);
}
}
main()
{
char *s="I am a student.She is a physician";
void maxword(char *s);
maxword(s);
}
尽量在不更改你原有的程序上,做出了一些更改。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询