博主不定期更新【保研/推免、C/C++、5G移动通信、Linux、生活随笔】系列文章,喜欢的朋友【点赞+关注】支持一下吧!
你的程序要读入一行文本,其中以空格分隔为若干个单词,以.
结束。你要输出每个单词的长度。这里的单词与语言无关,可以包括各种符号,比如it's
算一个单词,长度为4。注意,行中可能出现连续的空格;最后的.
不计算在内。
输入格式:
输入在一行中给出一行文本,以.
结束
输出格式:
在一行中输出这行文本对应的单词的长度,每个长度之间以空格隔开,行末没有最后的空格。
输入样例:
It's great to see you here.
输出样例:
4 5 2 3 3 4
#include <>
int main()
{
char a[1000];
int i=0;
scanf("%c", &a[i]);
int n=0; //n用来记数单词长度,此处n初始化为0是由于读入空格时会增加n的值,所以读第一个字符时,n初始化为0
int b[1000]={0};
int j=0;
/*排除开头空格的影响*/
while (a[i] == ' ')
{
scanf("%c", &a[i]);
}
while (a[i] != '.') //读入单词,到.结束
{
i++;
scanf("%c", &a[i]);
n++;
/*判断是否出现“ ”或“.” ,出现后将该单词长度n记录下来,之后重置n*/
if (a[i] == ' ' || a[i] == '.')
{
if (n>0) //避免连续多个空格影响输出
{
b[j++]=n;
}
n = -1; //此处重置n的值,用来记数下一个单词长度,此时还未开始读字符,初始值应设为-1,读入一个字符后,n就变成了0,同第8行。
}
}
/*输出结果,并通过数组判断是否到达最后一个单词,以避免末尾多出空格*/
for (j=0;j<1000;j++)
{
if (b[j]>0)
{
printf("%d", b[j]);
if (b[j+1]>0) //如果b[j]不是最后一个数,则输出空格
{
printf(" ");
}
}
}
return 0;
}
本题难点在于格式的要求,以及输入的各种变化(例如行首,行间,行尾多空格)。我的思路似乎有点乱,因为程序是根据OJ的测试点逐渐添加修改的,暂时没有想到更流畅的方法。