我是C语言初学者,帮我用一个函数来实现将一行字符串中最长的单词输出。此行字符串从主函数传递给该函数.
3个回答
展开全部
C语言 :写一个函数 输入一行字符 将此字符串中最长的单词输出
悬赏分:0 - 离问题结束还有 14 天 23 小时
8-10
#include <iostream>
void main()
{
int word(char c);
int longest(char str[]);
int i;
char str[80];
printf("输入一行字符串\n\n");
gets(str);
printf("\n\n最长的单词为:\n\n");
for(i=longest(str);word(str[i]);i++)
printf("%c",str[i]);
printf("\n");
}
int word(char c)
{
if((c>='a'&&c<='z')||(c>='A'&&c<='Z')) return 1;
else return 0;
}
int longest(char str[])
{
int i,flag=1,len=0,point,max_len=0,max_point;
for(i=0;i<=strlen(str);i++)//解析每个字符
{
if(word(str[i])) //是英文字母的话
{
if(flag==1) //成立的话说明这个英文字母是单词的第一个
{
point=i; //单词第一个找到后改变标志
flag=0;
}
else len++; //开始对这个单词长度进行累加
}
else //非英文字母的话
{
flag=1; //等待第一个英文字母的出现,所以flag=1(要是下一个是英文字母的话就能执行上面的if)
if(len>max_len)//之前累加的单词长度是否比上一个单词更长(第一次的话max_len初始化为0,len必大于max_len)
{
max_len=len;//将单词长度保存下来
max_point=point;//将最长单词的第一个英文字母在字符串中的位置保存下来
}
len=0;
}
}
return (max_point);
}
悬赏分:0 - 离问题结束还有 14 天 23 小时
8-10
#include <iostream>
void main()
{
int word(char c);
int longest(char str[]);
int i;
char str[80];
printf("输入一行字符串\n\n");
gets(str);
printf("\n\n最长的单词为:\n\n");
for(i=longest(str);word(str[i]);i++)
printf("%c",str[i]);
printf("\n");
}
int word(char c)
{
if((c>='a'&&c<='z')||(c>='A'&&c<='Z')) return 1;
else return 0;
}
int longest(char str[])
{
int i,flag=1,len=0,point,max_len=0,max_point;
for(i=0;i<=strlen(str);i++)//解析每个字符
{
if(word(str[i])) //是英文字母的话
{
if(flag==1) //成立的话说明这个英文字母是单词的第一个
{
point=i; //单词第一个找到后改变标志
flag=0;
}
else len++; //开始对这个单词长度进行累加
}
else //非英文字母的话
{
flag=1; //等待第一个英文字母的出现,所以flag=1(要是下一个是英文字母的话就能执行上面的if)
if(len>max_len)//之前累加的单词长度是否比上一个单词更长(第一次的话max_len初始化为0,len必大于max_len)
{
max_len=len;//将单词长度保存下来
max_point=point;//将最长单词的第一个英文字母在字符串中的位置保存下来
}
len=0;
}
}
return (max_point);
}
展开全部
#include<stdio.h>
#include<string.h>
int alphabetic(char c)
{
if((c >= 'A' && c <= 'Z') || (c >= 'a' && c <= 'z'))
return 1;
else
return 0;
}
int find(char str[])
{
int i;
int len = 0,length = 0,flag = 1,place,point;
for(i = 0;i <= strlen(str);i++)
{
if(alphabetic(str[i]))
{
if(flag)
{
point = i;
flag = 0;
}
else
len++;
}
else
{
flag = 1;
if(len > length)
{
length = len;
place = point;
len = 0;
}
}
}
return place;
}
void main()
{
int k;
char array[100];
printf("Input a line of words:\n");
gets(array);
printf("The longest words is:\n");
for(k = find(array);alphabetic(array[k]);k++)
printf("%c",array[k]);
printf("\n");
getch();
}
#include<string.h>
int alphabetic(char c)
{
if((c >= 'A' && c <= 'Z') || (c >= 'a' && c <= 'z'))
return 1;
else
return 0;
}
int find(char str[])
{
int i;
int len = 0,length = 0,flag = 1,place,point;
for(i = 0;i <= strlen(str);i++)
{
if(alphabetic(str[i]))
{
if(flag)
{
point = i;
flag = 0;
}
else
len++;
}
else
{
flag = 1;
if(len > length)
{
length = len;
place = point;
len = 0;
}
}
}
return place;
}
void main()
{
int k;
char array[100];
printf("Input a line of words:\n");
gets(array);
printf("The longest words is:\n");
for(k = find(array);alphabetic(array[k]);k++)
printf("%c",array[k]);
printf("\n");
getch();
}
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
全世界英语单词多的数不清啊?你叫我们怎么做?
还最长的单词呢,倒
还最长的单词呢,倒
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询