C基础寒假练习(4)

输入带空格的字符串,求单词个数、

复制代码
#include <stdio.h>
// 计算字符串长度的函数
size_t my_strlen(const char *str) 
{
    size_t len = 0;
    while (str[len] != '\0') 
    {
        ++len;
    }
    return len;
}

int main() 
{
    char str[100];
    printf("请输入一个字符串: ");
    fgets(str, sizeof(str), stdin);

    // 如果存在换行符,则将其移除
    size_t len = my_strlen(str);
    if (len > 0 && str[len - 1] == '\n') 
    {
        str[len - 1] = '\0';
    }

    int state = 0; // 0: 在单词外, 1: 在单词内
    int wordCount = 0;
    const char *ptr = str;

    while (*ptr) {
        if (*ptr == ' ' || *ptr == '\t' || *ptr == '\n')
        {
            state = 0;
        } 
        else if (state == 0) 
        {
            state = 1;
            ++wordCount;
        }
        ++ptr;
    }

    printf("单词个数: %d\n", wordCount);

    return 0;
}

下面是对代码的详细解释:

1. my_strlen 函数

复制代码
size_t my_strlen(const char *str) 
{
    size_t len = 0;
    while (str[len] != '\0') 
    {
        ++len;
    }
    return len;
}

这个函数用于计算字符串的长度,即字符串中字符的数量(不包括终止符 \0)。它通过遍历字符串直到遇到终止符 \0 来计算长度。

2. main 函数

复制代码
int main() 
{
    char str[100];
    printf("请输入一个字符串: ");
    fgets(str, sizeof(str), stdin);
  • 定义了一个字符数组 str,大小为 100。
  • 使用 fgets 从标准输入读取一行字符串并存储在 str 中。fgets 会读取最多 sizeof(str) - 1 个字符,并在末尾添加一个空字符 \0

3. 移除换行符

复制代码
    size_t len = my_strlen(str);
    if (len > 0 && str[len - 1] == '\n') 
    {
        str[len - 1] = '\0';
    }
  • 调用 my_strlen 获取字符串的长度。
  • 如果字符串的最后一个字符是换行符 \n,则将其替换为空字符 \0,以去除换行符。

4. 计算单词数量

复制代码
    int state = 0; // 0: 在单词外, 1: 在单词内
    int wordCount = 0;
    const char *ptr = str;

    while (*ptr) {
        if (*ptr == ' ' || *ptr == '\t' || *ptr == '\n')
        {
            state = 0;
        } 
        else if (state == 0) 
        {
            state = 1;
            ++wordCount;
        }
        ++ptr;
    }
  • 初始化状态变量 state 为 0,表示当前不在单词内。
  • 初始化单词计数器 wordCount 为 0。
  • 使用指针 ptr 遍历字符串。
  • 如果当前字符是空格、制表符或换行符,将状态设置为 0(表示不在单词内)。
  • 如果当前字符不是空白字符且状态为 0,说明遇到了一个新单词,将状态设置为 1,并增加单词计数器。
  • 继续移动指针到下一个字符。

5. 输出结果

复制代码
    printf("单词个数: %d\n", wordCount);
    return 0;
}
  • 打印计算出的单词数量。
  • 返回 0,表示程序正常结束。

总结

这段代码通过遍历用户输入的字符串,识别出其中的单词并统计其数量。主要步骤包括读取输入、去除换行符、遍历字符串并统计单词数量。

相关推荐
182******20837 分钟前
2026年java后端还有机会吗?还能找到工作吗?
java·开发语言
kyriewen11 分钟前
你的前端滤镜慢得像PPT?用Rust+WebAssembly,一秒处理4K图
前端·rust·webassembly
kyriewen1120 分钟前
你等的Babel编译,够喝三杯咖啡了——用Rust重写的SWC,只需眨个眼
开发语言·前端·javascript·后端·性能优化·rust·前端框架
XS03010627 分钟前
Java基础 map集合
java·哈希算法·散列表
IT_陈寒32 分钟前
SpringBoot自动配置坑了我,原来要这样绕过去
前端·人工智能·后端
东方小月42 分钟前
Claude Code 完整上手指南:MCP、Skills、第三方模型配置一次搞定
前端·人工智能·后端
凤山老林1 小时前
从0到1搭建企业级权限管理系统:Spring Boot + JWT + RBAC实战指南
java·spring boot·后端·权限管理·rbac
XZ探长1 小时前
基于 Trae Solo 移动办公修复 Vue3 前端服务问题
前端
逍遥德1 小时前
AI时代,计算机专业大学生学习指南
java·javascript·人工智能·学习·ai编程
蝎子莱莱爱打怪1 小时前
Claude Code 省 Token 小妙招:RTK + Caveman 组合拳
前端·人工智能·后端