统计并找出一句英文句子中最长的一个单词(C语言)

/*注意:句子的输入格式为 单词+空格+单词...
例如:“the apple is red”*/
#include<stdio.h>
#include<string.h>
#include<windows.h>
#define N 30
#define M 30
#define Q 20
int FindMax(int a[], int n);
void FindWords(char s[], char a[], int count[], int j);

/*找出数组的最大值并返回下标*/
int FindMax(int a[], int n)
{
    int max, i, j = 0;
    max = a[0];
    for (i = 1; i < n; i++)
    {
        if (max < a[i])
        {
            max = a[i];
            j = i;
        }
    }
    return j;
}

/*找出s[]中最长的单词并将它赋值给新开的字符串数组*/
void FindWords(char s[], char a[], int count[], int j)
{
    int sum = 0, i, k = 0, p;
    for (i = 0; i < j; i++)
    {
        sum += count[i];
        k++;
    }
    sum += k;
    if (sum != count[0])
    {
        p = sum;
        for (i = 0; i < count[j]; i++,p++)
        {
            a[i] = s[p];
            /*printf("s[p]---%c  ",s[p]);
            printf("a[i]---%c\n",a[i]);*/   //用于测试赋值过程是否正确
        }
        a[i] = '\0';
    }
    else
    {
        p = 0;
        for (i = 0; i < count[j]; i++,p++)
        {
            a[i] = s[p];
            /*printf("s[p]---%c  ",s[p]);
            printf("a[i]---%c\n",a[i]);*/  //用于测试赋值过程是否正确
        }
        a[i] = '\0';
    }

}

/*主函数*/
int main()
{
    int count[N], a, i, j = 0, k = 0;
    char s[M], b[Q];
    printf("2016/01/28 作者:肖庆鸿\n\n请输入一句英文:");
    gets(s);
    a = strlen(s);
    for (i = 0; s[i] != '\0'; i++)
    {
        if((s[i] >= 65&&(s[i] <= 90))||((s[i] >= 97)&&(s[i] <= 122)))
        {
            k++;
            count[j] = k;
        }
        else if (s[i] == ' ')
        {
            j++;
            k = 0;
        }
    }
    k = FindMax(count, j+1);
    FindWords(s, b, count, k);
    printf("这句话中最长的单词是%s,",b);
    //puts(b);
    printf("该单词共有%d个字母\n",count[k]);

    system("pause");
    return 0;
}
  • 6
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,以下是用 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 个字符开始。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值