题目:
输入一行单词序列,相邻单词之间由1个或多个空格间隔,请对应地计算各个单词的长度。
1. 输入要求:一行单词序列,最少1个单词,最多300个单词,单词之间用至少1个空格间隔。单词序列总长度不超过1000。
2. 输出要求:依次输出对应单词的长度,之间以逗号间隔。
3. 注意:如果有标点符号(如连字符,逗号),标点符号算作与之相连的词的一部分。没有被空格间开的符号串,都算作单词。
分析:
1. 本题输入要求为一行句子,故应使用gets()来获取输入,而不应使用scanf("%s",s);否则将无法获取到空格之后的单词。
2.题中要求有一个字符数组来存储输入的句子,有一个长度int数组来存储每个单词的长度(包含标点符号)。还需要一个一个current_len变量来记录每个单词的长度
3.由于遍历过程对每个单词的截断判断的处理,可能无法正确处理最后一个单词,故须另作处理。
4.输出格式的控制,除第一个单词长度外,其后每一个输出都为逗号+对应单词长度。
代码:
#include <stdio.h>
#include <string.h>
#define Max 1000
#define Max1 300
int main() {
char sen[Max];
int lengths[Max1];
int index = 0;
int current_len = 0;
int i=0;
gets(sen);
sen[strlen(sen)] = '\0';
for(i=0;sen[i]!='\0';i++){
if(sen[i]==' '&&sen[i-1]!=' '){
if(current_len>0){
lengths[index++]=current_len;
current_len=0;
}
}else if(sen[i]!=' ') current_len++;
}
if(current_len>0) lengths[index++]=current_len;
for(int j=0;j<index;j++){
if(j>0) printf(",");
printf("%d",lengths[j]);
}
printf("\n");
return 0;
}
测试:
样例输入
She was born in 1990-01-02 and from Beijing city.
样例输出
3,3,4,2,10,3,4,7,5