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