已有文本文件,统计文件中字符出现的次数并输出

统计文件中字符出现的次数并输出

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define N 100

typedef struct ch {
char a; //字符值
int num; //次数
struct ch* next;
}Ch; //定义结构体

struct ch* tongji(char[], Ch*); //统计字符次数并插入链表的函数
void printc(Ch*); //输出

int main()
{
FILE* fp;
char a[N];
int i = 0;
char c;
if ((fp = fopen(“D:\c\test.txt”, “r”)) == NULL)
{
printf(“cannot open this file”);
exit(0);
}
c = fgetc(fp);
while (!feof(fp))
{
a[i++] = c;
c = fgetc(fp);
printf("%c", c);
}
a[i] = ‘\0’;

Ch* p, * q;
q=p = (Ch*)malloc(sizeof(Ch));
if (!p)
	exit(0);
p->next = NULL;
q = tongji(a, p);
printc(q);

return 0;

}

Ch* tongji(char a[], Chhead) {
int i = 0;
Ch
p, * q;

for (i; a[i] != '\0'; i++)
{
	p = head;
	while (p->next)
	{
		if (p->next->a == a[i])
		{
			p->next->num++;
			break;
		}
		else
			p = p->next;
	}
		if (p->next == NULL)
		{
			q = (Ch*)malloc(sizeof(Ch));
			if (!q)
				exit(0);
			p->next = q;
			q->a = a[i];
			q->next = NULL;
			q->num = 1;
		}

	}
return head;

}
void printc(Ch* head)
{
Ch* p = head;
while (p->next)
{
printf("%5c %5d\n", p->next->a, p->next->num);
p = p->next;
}
}
在这里插入图片描述

  • 3
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个Java程序,可以实现统计文本文件字符出现次数并按照出现次数排序的功能: ```java import java.io.*; import java.util.*; public class ChineseCharCount { public static void main(String[] args) { String filename = "test.txt"; // 待统计文件名 Map<Character, Integer> charMap = new HashMap<>(); // 用于存储字符出现次数的映射 try (BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream(filename), "UTF-8"))) { String line; while ((line = reader.readLine()) != null) { for (int i = 0; i < line.length(); i++) { char c = line.charAt(i); if (isChineseChar(c)) { Integer count = charMap.get(c); if (count == null) { charMap.put(c, 1); } else { charMap.put(c, count + 1); } } } } } catch (IOException e) { e.printStackTrace(); } List<Map.Entry<Character, Integer>> charList = new ArrayList<>(charMap.entrySet()); // 将映射转换为列表 charList.sort((e1, e2) -> e2.getValue().compareTo(e1.getValue())); // 按照出现次数从大到小排序 for (Map.Entry<Character, Integer> entry : charList) { System.out.println(entry.getKey() + ": " + entry.getValue()); } } // 判断一个字符是否为字符 private static boolean isChineseChar(char c) { Character.UnicodeBlock ub = Character.UnicodeBlock.of(c); return ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS || ub == Character.UnicodeBlock.CJK_COMPATIBILITY_IDEOGRAPHS || ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS_EXTENSION_A || ub == Character.UnicodeBlock.GENERAL_PUNCTUATION || ub == Character.UnicodeBlock.CJK_SYMBOLS_AND_PUNCTUATION || ub == Character.UnicodeBlock.HALFWIDTH_AND_FULLWIDTH_FORMS; } } ``` 程序首先读取指定的文本文件,逐行遍历文件的每个字符,如果一个字符字符,则将其加入到一个映射,并记录其出现次数。最后,将映射转换为列表并按照出现次数从大到小排序,输出结果。 程序使用了`isChineseChar`方法来判断一个字符是否为字符,该方法判断的依据是该字符所属的`UnicodeBlock`是否为字符所使用的`UnicodeBlock`。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值