117.info
人生若只如初见

c语言怎么统计文本中单词的个数

可以通过以下步骤来统计文本中单词的个数:

  1. 打开文本文件并读取内容。
  2. 遍历文件内容,逐个字符判断是否为字母或数字,如果是则将该字符添加到一个临时字符串中。
  3. 当遇到非字母或数字的字符时,判断临时字符串是否为空,如果不为空则将该字符串单词计数,并清空临时字符串。
  4. 继续遍历文本内容,直至全部遍历完毕。
  5. 最后输出统计的单词个数。

以下是一个简单的示例代码:

#include 
#include 

int main() {
    FILE *file;
    char ch;
    char word[50];
    int count = 0;
    
    file = fopen("text.txt", "r");
    
    if (file == NULL) {
        printf("Unable to open file.\n");
        return 1;
    }
    
    while ((ch = fgetc(file)) != EOF) {
        if (isalnum(ch)) {
            strncat(word, &ch, 1);
        } else {
            if (strlen(word) > 0) {
                count++;
                word[0] = '\0';
            }
        }
    }
    
    if (strlen(word) > 0) {
        count++;
    }
    
    printf("Total words: %d\n", count);
    
    fclose(file);
    
    return 0;
}

在上面的示例代码中,假设要统计的文本内容保存在名为"text.txt"的文本文件中。代码会逐个读取文件中的字符,并判断是否为字母或数字。如果是字母或数字,则将该字符添加到临时字符串"word"中,当遇到非字母或数字字符时,判断临时字符串是否为空,如果不为空则将计数加一,并清空临时字符串。最后输出统计的单词个数。

未经允许不得转载 » 本文链接:https://www.117.info/ask/fee49AzsLAQRRDFE.html

推荐文章

  • C语言进程句柄怎么读取

    在C语言中,可以通过使用标准库函数fopen打开进程句柄,并使用fread函数读取句柄中的数据。
    以下是一个简单的示例代码:
    #include int main() { FILE ...

  • C语言定时器的使用方法是什么

    C语言中使用定时器的方法有多种,其中常用的有以下几种: 使用sleep函数:sleep函数可以让程序暂停指定的时间,单位是秒。例如,要让程序暂停2秒,可以使用sleep...

  • c语言如何减慢打印速度

    要减慢C语言的打印速度,可以使用以下方法: 使用延时函数:在每次打印之间插入一个延时函数,可以使用sleep()函数或usleep()函数来实现延时。这样可以控制打印速...

  • c语言怎么实现最简单的计时器

    在C语言中,可以使用time.h头文件中的time函数来实现一个简单的计时器。下面是一个简单的示例代码:
    #include #include int main() { time_t start_time, e...

  • oracle怎么修改表字段名称

    要修改表字段名称,可以使用ALTER TABLE语句。以下是一个示例:
    ALTER TABLE table_name RENAME COLUMN old_column_name TO new_column_name; 在这个示例中...

  • mysql怎么给表添加多个字段

    要给表添加多个字段,可以使用ALTER TABLE语句,并在后面使用ADD关键字来指定要添加的字段及其数据类型。
    例如,要给表users添加两个字段email和phone,可以...

  • plsql怎么查看表字段类型

    在PL/SQL中查看表字段类型,可以使用以下几种方法: 使用DESCRIBE语句:可以在SQL*Plus会话中使用DESCRIBE语句来查看表的结构和字段类型。例如: DESCRIBE table...

  • db2怎么按日期创建表分区

    在DB2中,可以通过以下步骤按日期创建表分区: 首先,创建一个分区表,指定分区键为日期字段。例如,可以使用以下语句创建一个按日期分区的表: CREATE TABLE my...