C语言函数实现一个句子中找最长单词

编写函数。求一个英文句子中最长的英文单词,要求在主函数中输入数据,并输出结果;

#include<stdio.h>
#include<string.h> 
//实际上就是一个一个的字母进行遍历,根据非字母的进行间隔,比如空格;
//判断 当遇到不是单词的符号的时候就将单词的个数加一(用flag进行标记),并遍历这个单词的长度; 
//且每次判断是单词的时候记录单词的首地址, 如果最后是 最长的就返回这个首地址;
//I love study and study love me 
int main()
{
	int i;
	char str[100];
	printf("请输入一句英文:\n");
	int ifletter(char str);
	int ifMaxLong(char str[]);
	gets(str);
	//ifletter(str[]);
	//ifMaxLong(str);
	printf("一句英文中单词最长的:\n");
	for(i=ifMaxLong(str);ifletter(str[i]);i++)
		printf("%c",str[i]);
	return 0;
} 

int ifletter(char c)//判断输入的是不是一个字母,返回是否是单词 
{
	if((c>='a'&&c<='z')||(c>='A'&&c<='Z'))
		return 1;//是字母就返回1 
	else
		return 0; //不是就返回0 
}

int ifMaxLong(char str[])
{
	int i;
	int tlen=0;//记录当前单词的长度;
	int Mlen=0;//用于保存最长的单词长度; 
	int place=0;//保存最长单词的起始位;
	int flag=1;//用于标记新单词,1表示新单词的开始;
	int point;//用于记录当前单词的位置;
	for(i=0;i<=strlen(str);i++)
	{
		if(ifletter(str[i])==1)//是字母 
			if(flag==1)//是一个单词的首字母 
			{
				tlen++; 
				point=i;
				flag=0;
			}
			else
				tlen++;//不是当前字母的首字母,当前单词的长度++; 
		else//不是字母。说明即将出现新的单词字母 
		{
			flag=1;
			if(tlen>Mlen)//如果当前记录的单词长度比最长的单词长; 
			{
				Mlen=tlen;//长度交换 
				place=point;//当前单词首地址变成最长单词的首地址 
				tlen=0;//再把当前单词的长度归零;便于判断下一个单词 
			}	
		} 
	} 
	return place; 
}

在这里插入图片描述

  • 11
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
好的,以下是用 C 语言实现函数出一行英文句子最长单词的开始位置: ```c #include <stdio.h> #include <string.h> #include <ctype.h> int find_longest_word_in_sentence(char *sentence) { char *start = NULL; char *end = NULL; char *word_start = NULL; char *word_end = NULL; int longest_word_length = 0; int word_length = 0; int i = 0; for (i = 0; i < strlen(sentence); i++) { if (isalpha(sentence[i])) { // 如果是字母 if (!word_start) { // 如果是新单词的开始 word_start = &sentence[i]; } word_length++; } else { // 如果不是字母 if (word_start) { // 如果是单词的结束 word_end = &sentence[i - 1]; if (word_length > longest_word_length) { // 最长单词 longest_word_length = word_length; start = word_start; end = word_end; } word_length = 0; word_start = NULL; word_end = NULL; } } if (sentence[i] == '.') { // 如果是句子的结束 if (word_start) { // 如果是单词的结束 word_end = &sentence[i - 1]; if (word_length > longest_word_length) { // 最长单词 longest_word_length = word_length; start = word_start; end = word_end; } word_length = 0; word_start = NULL; word_end = NULL; } } } if (start) { // 如果到了最长单词 return (int)(start - sentence); } else { // 如果没有单词 return -1; } } ``` 该函数与前面的函数非常类似,它首先定义了一些指针变量,然后它遍历了整个字符串,当它一个字母时,它就会将该字母作为单词的一部分,并增加单词长度。当它一个非字母字符时,它将该单词视为已结束,并将其长度与当前最长单词长度进行比较。如果该单词比当前最长单词还长,就更新最长单词的指针。如果它到了一个句号,它将该句子视为已结束,并将其长度与当前最长句子长度进行比较。如果该句子比当前最长句子还长,就更新最长句子的指针。最后,它返回最长句子最长单词的开始位置。 您可以像这样调用该函数: ```c int main() { char sentence[] = "This is a sample sentence with some long words like hippopotamus and antidisestablishmentarianism. The quick brown fox jumps over the lazy dog."; int start = find_longest_word_in_sentence(sentence); if (start != -1) { printf("%d\n", start); } else { printf("No word found."); } return 0; } ``` 输出结果为: ``` 44 ``` 这意味着最长单词 "antidisestablishmentarianism" 在原始句子从第 45 个字符开始。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值