C语言题目:单词个数统计

题目描述

编写一个程序,输入一个字符串(长度不超过80),然后统计出该字符串当中包含有多少个单词。例如:字符串"this is a book"当中包含有4个单词。

输入格式

输入一个字符串(长度不超过80),由若干个单词组成,单词之间用一个空格隔开。

输出格式

输出一个整数,即单词的个数。

样例输入

复制代码
this is a book

样例输出

复制代码
4

代码流程及分析

1. 引入头文件

代码首先引入了stdio.h头文件,这是C语言标准输入输出库,用于处理输入输出函数。

2. 主函数定义

main函数是程序的入口点,它没有接收任何参数,也没有返回值。

3. 定义变量

main函数内部,定义了以下变量:

  • int t = 1;:用于存储单词计数,初始化为1,因为至少有一个单词。
  • int j = 0;:用于记录输入字符的数量。
  • char text[999];:一个字符数组,用于存储用户输入的文本,数组大小为999,意味着最多可以存储999个字符。

4. 输入循环

使用一个while循环来读取用户输入的字符:

  • scanf("%c", &text[j]):使用scanf函数读取一个字符,并将其存储在text[j]中。
  • 循环条件是scanf的返回值不等于EOF(文件结束符),这意味着循环将持续进行,直到输入结束。

5. 更新字符计数

在循环内部,每次读取一个字符后,j的值增加1。

6. 单词计数

循环结束后,使用一个for循环遍历text数组:

  • 循环变量i从0开始,到j结束(包括j),因为j是数组中最后一个有效字符的索引。
  • 如果text[i]是空格字符(' '),则t的值增加1,用于计数单词。

7. 输出结果

使用printf函数输出单词计数t,格式化字符串"%d\n"表示输出的是一个整数,后跟一个换行符。

8. 程序结束

main函数返回0,表示程序正常结束。

源代码

复制代码
#include <stdio.h>
int main(void)
{
	int t = 1;
	int j = 0;
	char text[999];
	while (scanf("%c", &text[j]) != EOF)
	{
		j++;
	}
	for (int i = 0; i <= j; i++)
	{
		if (text[i] == ' ')
			t++;
	}
	printf("%d\n", t);
	return 0;
}
相关推荐
式51613 小时前
CUDA编程学习(四)内存拷贝
学习·算法
Barkamin13 小时前
直接插入排序的简单实现
java·算法·排序算法
Frostnova丶13 小时前
LeetCode 1622. 奇妙序列
算法·leetcode
自在极意功。14 小时前
ArrayList扩容机制
java·开发语言·算法·集合·arraylist
芯联智造14 小时前
【stm32简单外设篇】- 震动传感器
c语言·stm32·单片机·嵌入式硬件
健康平安的活着14 小时前
java8案例对list[过滤、分组,转换,查找等]清洗逻辑
java·数据结构·list
计算机安禾14 小时前
【C语言程序设计】第26篇:变量的作用域与生命周期
c语言·开发语言·数据结构·算法·leetcode·visual studio code·visual studio
2401_8980751214 小时前
C++中的智能指针详解
开发语言·c++·算法
Elsa️74614 小时前
排序算法实现(基于408)
数据结构·算法·排序算法
xiaoye-duck14 小时前
《算法题讲解指南:递归,搜索与回溯算法--二叉树中的深搜》--10.二叉搜索树中第k小的元素,11.二叉树的所有路径
c++·算法·深度优先·递归