统计一篇英文短文中单词的个数 一、项目描述 我们在阅读英文文章时,为了辨别出每一个单词,会发现英文短文中每个单词都是用空格分开的,现在假设有一篇英文短文,每个单词之间是用空格分开的,试编写一个算法,按照空格数统计短文中单词的个数?例如:图4-1所示的一篇英文短文,应该含有49个单词。 To a large degree, the measure of our peace of mind is determined by how much we are able to live on the present moment. Irrespective of what happened yesterday or last year, and what may or may not happen tomorrow, the present moment is where you are always! 图4-1英文短文示例 二、项目分析 要统计单词的个数先要解决如何判别一个单词,应该从输入行的开头一个字符一个字符地去判别。假定把一篇英文短文放在数组s中,那么就相当于从s[0]开始逐个检查数组元素,经过一个空格或者若干个空格符之后找到的第一个字母就是一个单词的开头,此时利用一个计数器num进行累加1运算,在此之后若连续读到的是非空格字符,则这些字符属于刚统计到的那个单词,因此不应该将计数器num进行累加1,下一次计数应该是在读到一个空格或者若干个空格符之后再遇到非空格字符开始。因此,统计一个单词时不仅要满足当前所检查的这个字符是非空格,而且要满足所检查的前一个字符是空格。
时间: 2023-11-27 12:55:08 浏览: 90
三、代码实现
可以使用循环遍历字符串的方式实现统计单词个数的算法,具体实现如下:
```python
def count_words(text):
# 初始化计数器为0
count = 0
# 初始化前一个字符为空格
prev_char = ' '
# 遍历字符串的每个字符
for char in text:
# 若当前字符为非空格且前一个字符为空格,则计数器加1
if char != ' ' and prev_char == ' ':
count += 1
# 更新前一个字符为当前字符
prev_char = char
# 返回单词个数
return count
```
四、测试代码
可以使用如下代码测试上述算法:
```python
text = "To a large degree, the measure of our peace of mind is determined by how much we are able to live on the present moment. Irrespective of what happened yesterday or last year, and what may or may not happen tomorrow, the present moment is where you are always!"
word_count = count_words(text)
print("单词个数:", word_count)
```
运行结果如下:
```
单词个数: 49
```
阅读全文