字符串的一道题,我的答案超时了,希望大神在原有基础上帮我改正

描述
输入1行句子(不多于200个单词,每个单词长度不超过100),只包含字母、空格和逗号。单词由至少一个连续的字母构成,空格和逗号都是单词间的间隔。
试输出第1个最长的单词和第1个最短单词。
输入
一行句子。
输出
两行输出:
第1行,第一个最长的单词。
第2行,第一个最短的单词。
样例输入
I am studying Programming language C in Peking University
样例输出
Programming
I
提示
如果所有单词长度相同,那么第一个单词既是最长单词也是最短单词。

#include<stdio.h>
#include<string.h>
int main()
{
    char ch[222222];
    int i,max=0,min=120,a,b,c,d,t=0;
    gets(ch);
    int len=strlen(ch);
    for(i=0;i<len;i++)
    {

        if(ch[i]==' ')
        {

            int n=i-t+1;
            if(n>max) {max=n;a=t;b=i-1;}
            if(n<min) {min=n;c=t,d=i-1;}
            t=i+1;
        }
    }

    for(i=a;i<=b;i++)
        printf("%c",ch[i]);
        printf("\n");
    for(i=c;i<=d;i++)
        printf("%c",ch[i]);
    return 0;
}

地址http://noi.openjudge.cn/ch0107/25/

根据题意,空格和逗号都是分割符
if(ch[i]==' ')
->
if(ch[i]==' ' || ch[i] == ',')


#include<stdio.h>
#include<string.h>
int main()
{
    char ch[22222];
    int i,max=0,min=120,a,b,c,d,t=0;
    a=b=c=d=0;
    gets(ch);
    int len=strlen(ch);
    for(i=0;i<=len;i++)
    {

        if(ch[i]==' ' || ch[i]==',' || ch[i]=='\0')
        {

            int n=i-t;
            if (n > 0)
            {
            if(n>max) {max=n;a=t;b=i-1;}
            if(n<min) {min=n;c=t,d=i-1;}
            }
            t=i+1;
        }
    }

    for(i=a;i<=b;i++)
        printf("%c",ch[i]);
        printf("\n");
    for(i=c;i<=d;i++)
        printf("%c",ch[i]);
    return 0;
}

http://noi.openjudge.cn/ch0107/solution/22519898/
accepted了

你没考虑的情况
1、出现逗号的情况
2、空间连续出现的情况如:(I am studying Programming language C in Peking University)( studying Programming之间有两个逗号)
3、逗号空格连续出现的情况

#include<bits/stdc++.h>
using namespace std;
int main()
{
char ss[10000], s[10000];
char maxa[10000], mina[10000];
int min = 9999, max = 0, l = 0;
cin.getline(ss, 2000);
for (int i = 0; i < strlen(ss); ++i)
{
if (ss[i] == ','||ss[i] == ' ')
{
ss[i] = ' ';
}
}
for (int i = 0; i < strlen(ss); ++i)
{
if (ss[i] != ' ')
{
s[++l] = ss[i];
}
else
{
if (l > max) for (int j = 1; j <= l; ++j) maxa[j] = s[j], max = l;
if (l < min) for (int j = 1; j <= l; ++j) mina[j] = s[j], min = l;
l = 0;
}
}
if (l > max) for (int j = 1; j <= l; ++j) maxa[j] = s[j], max = l;
if (l < min) for (int j = 1; j <= l; ++j) mina[j] = s[j], min = l;
for (int i = 1; i <= max; ++i)
{
cout << maxa[i];
}
cout << endl;
for (int i = 1; i <= min; ++i)
{
cout << mina[i];
}
return 0;
}