统计文本中字母的频次(不区分大小写)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_NUM 10240
 
void count(char* n)
{
    int i = 0, s[26] = { 0 };
    while (n[i] != NULL)
    {
        if (n[i] >= 'A' && n[i] <= 'Z')
        {
            n[i] += 32;
            s[n[i] - 'a']++;
            i++;
        }
        else if (n[i] >= 'a' && n[i] <= 'z')
        {
            s[n[i] - 'a']++;
            i++;
        }
        else
            i++;
    }
 
    for (i = 0; i < 26; i++)
    {
        printf("%c出现:%d次\n", (char)(i + 'a'), s[i]);
    }
}
int main() {
    char buf[MAX_NUM];          //字符缓冲区
    FILE* fp;
    //fopen("doc.txt", "r+"),读取文本中的内容
    if ((fp = fopen("doc.txt", "r+")) == NULL) {
        perror("the file fail to read");
        exit(1);
    }
    while (!feof(fp) && !ferror(fp)) {  //文件读取结束或出错则退出
   //while(fgets(buf,MAX_NUM,fp) != NULL)
        fgets(buf, MAX_NUM, fp);//每次读取一行或者MAX_NUM个字符
        printf("内容为:%s \n", buf);
        count(buf);
    }
    fclose(fp);             //关闭文件
    return 0;
}

 

作者:Hang Shao

出处:https://www.cnblogs.com/pam-sh/p/13941989.html

版权:本作品采用「知识共享」许可协议进行许可。

声明:欢迎交流! 原文链接 ,如有问题,可邮件(mir_soh@163.com)咨询.

posted @   PamShao  阅读(243)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示
more_horiz
keyboard_arrow_up dark_mode palette
选择主题