统计并找出一句英文句子中最长的一个单词(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;
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值