PTA-基础编程题目集-7-26-单词长度-C++基础版

PTA-基础编程题目集-7-26-单词长度

7-26 单词长度 (15 分)

你的程序要读入一行文本,其中以空格分隔为若干个单词,以.结束。你要输出每个单词的长度。这里的单词与语言无关,可以包括各种符号,比如it's算一个单词,长度为4。注意,行中可能出现连续的空格;最后的.不计算在内。

输入格式:

输入在一行中给出一行文本,以.结束

提示:scanf("%c",...);来读入一个字符,直到读到.为止。

输出格式:

在一行中输出这行文本对应的单词的长度,每个长度之间以空格隔开,行末没有最后的空格。

输入样例:

It's great to see you here.

输出样例:

4 5 2 3 3 4


    #include <stdio.h>
    #include <stdlib.h>
    #include <iostream>
    using namespace std;

    int main(){

        int world_length = 0;

        string str;
        getline(cin,str);

        //如果str只有一个结尾字符,则返回
        if (str[0] == '.'){
            return 0;
        }
    //    printf("%d\n",str.length());
        //首先判断该字符串中有没有连续的空格,如果有的话删掉多余的空格
        for (int k = 0; k < str.length(); ++k) {
            if (str[k] != 32 && str[k + 1] != 32){
                //如果当前字符不为空格,且下一个字符也不是空格,则单词长度加1
                world_length ++;
            } else if (str[k] != 32 && str[k + 1] == 32) {
                //如果当前字符不是空格,但是下一个字符是空格,则长度加1,并且打印单词长度,再把wordlength置0
                int count = 0;
                int temp = k + 1;
                for (int i = k + 1; i < str.length() - 1; ++i) {
                    if (str[i] == 32){
                        count ++;
                    }
                    if (count == str.length() - 2 - temp + 1){
                        //如果当前字符的下一个字符为空格,则从空格开始往后追踪
                        //直到末尾这中间所有的字符均为空格,则打印前面字符的wordlength
                        //wordlength之后没有空格
                        printf("%d",world_length + 1);
                        return 0;
                    }
                }
                world_length++;
                printf("%d ", world_length);
                world_length = 0;
            } else if (str[k] == 32 && str[k + 1] == 32) {
                //如果当前字符是空格,且下一个字符也是空格,则继续到下一轮
                continue;
            } else if (str[k] == 32 && str[k + 1] != 32){
                //如果当前字符是空格,且下一个字符是字符,则开始计数
                continue;
            }

            if (k == str.length() - 2){
                //当k等于str的长度时,判断倒数第二个字符是否为空格,最后一个字符是否为'.'
                if (str[k] == 32 && str[k + 1] == '.'){
                    printf("hhhhhhh\n");
                    return -1;
                } else if (str[k] != 32 && str[k + 1] == '.'){
                    printf("%d",world_length);
                }
            }
        }

        return 0;
    }

 

PTA-基础编程题目集-7-26-单词长度-C++基础版

网上看到很多很好的算法,但是这是我自己灵光乍现写出来的,哈哈,也算是自己走出去的第一小步,还是蛮有成就感的。诸以记之,与君共勉~