你的程序要讀入一行文本,其中以空格分隔為若干個單詞,以.結束。你要輸出每個單詞的長度。這里的單詞與語言無關,可以包括各種符號,比如it's算一個單詞,長度為4。注意,行中可能出現連續的空格;最后的.不計算在內。
輸入格式:
輸入在一行中給出一行文本,以.結束
提示:用scanf("%c",...);來讀入一個字符,直到讀到.為止。
輸出格式:
在一行中輸出這行文本對應的單詞的長度,每個長度之間以空格隔開,行末沒有最后的空格。
輸入樣例:
It's great to see you here.
輸出樣例:
4 5 2 3 3 4
解題思路:
這一題的測試點挺多。像下面的都要排除:
___________i起始有空格i love.有連續的空格.單獨一個點的情況。
這個程序最大的問題還可能在對末尾不能包含有空格的處理上。
本解法的思路是遇到下一個單詞時,才輸出上一個單詞的位數,判斷條件是統計的單詞位數大於 0 且其后有空格,這時候輸出的位數有空格。這樣最后一個單詞(它沒有下一個單詞)就可以單獨輸出不帶空格的位數。
文末的第二種解法提供了另外一種思路。增加了一個單詞統計量,第一個單詞輸出時前方不加空格,此后前方都加空格。
解題代碼:
#include<stdio.h> // 算法一
int main ()
{
int count = 0, count_0 = 0;
char n;
while((n = getchar()) != '.') {
if (n != ' ') {
if (count > 0 && count_0 > 0) { //當且僅當字母位數大於 0 時且后方有空格時才輸出帶有空格的位數
printf("%d ", count);
count = 0;
}
count ++;
count_0 = 0;
continue;
}
if (n == ' ') {
count_0 ++;
}
}
if (count > 0) { // 輸出最后一個單詞的個數
printf("%d\n", count);
} else {
printf("\n"); // 處理只有一個 . 的情況
}
return 0;
}
#include<stdio.h> // 算法二
int main(void)
{
char c;
int cnt = 0, count = 0; //統計單詞的個數
do {
scanf("%c", &c);
if ( cnt==0 && c==' ' ) {
continue;
} // 解決單詞與單詞之間多個空格的問題
if ( cnt==0 && c=='.') {
break;
} // 解決單詞與最后的'.'之間有空格的問題
if( c==' ' ) {
if ( count==0 ) {
printf("%d", cnt); //第一個單詞前不加空格
} else {
printf(" %d", cnt);
}
cnt = 0;
count++;
continue;
}
if( c=='.' ) {
if ( count==0 ) {
printf("%d", cnt);
} else {
printf(" %d", cnt);
}
break;
}
cnt++;
} while ( c!='.' );
return 0;
}
