C语言——统计字符数

Description  

判断一个由a~z这26个字符组成的字符串中哪个字符出现的次数最多。

Input  

第一行是测试数据的组数n,每组测试数据占1行,是一个由a~z这26个字符组成的字符串,每组测试数据之间有一个空行,每行数据不超过1000个字符且非空。

Output  

 n行,每行输出对应一个输入,包括出现次数最多的字符和该字符出现的次数,中间是一个空格。如果有多个字符出现的次数相同且最多,那么输出ASCII码最小的那一个字符。

Sample Input  


2
abbccc

adfadffasdf


Sample Output  


c 3
f 4
 

#include<stdio.h>
#include<string.h>

int main(){
	char a[1005];
	int T,n,i,max,c,j;
	int b[27]={0};
	scanf("%d",&T);
	while(T--){
		scanf("%s",&a);
		n=strlen(a);
		for(i=0;i<n;i++){
			c=a[i]-'a';
			b[c]++;
		}
		max=b[0];
		j=0;
		for(i=0;i<26;i++){
			if(b[i]>max){
				max=b[i];
				j=i;
			}
			b[i]=0;
		}
		printf("%c %d\n",'a'+j,max);
	}
}
		
注意 : j=0;

 

浙江大学C语言课程中有一个常见的练习题——**分类统计字符个数**,它要求编写一个程序来读取一段文本,并分别统计其中字母、数字、空格和其他字符的数量。 ### 实现思路 1. **输入处理**:从标准输入设备获取用户输入的一段字符串。 2. **遍历分析**:逐个检查每个字符属于哪一类(如是否是字母、数字等),并相应地增加对应计数器的值。 3. **结果输出**:最后打印出各类字符的具体数目。 下面是一个简单的代码示例: ```c #include <stdio.h> #include <ctype.h> // 提供了用于判断字符类型的函数原型声明 int main() { int letters = 0, digits = 0, spaces = 0, others = 0; printf("请输入一段文字:\n"); char ch; while ((ch = getchar()) != '\n') { // 当未遇到换符时继续循环 if (isalpha(ch)) // 如果当前字符是英文字母,则累加letters变量 ++letters; else if (isdigit(ch)) // 如果当前字符是阿拉伯数字,则累加digits变量 ++digits; else if (isspace(ch)) // 如果当前字符为空白符(包括制表符),则累加spaces变量 ++spaces; else // 其他情况均为非上述三者之一的情况,将others自增 ++others; } printf("\n统计结果如下:\n"); printf("字母数量:%d\n", letters); printf("数字数量:%d\n", digits); printf("空白符数量(含Tab):%d\n", spaces); printf("其他字符数量:%d\n", others); return 0; } ``` 此程序利用`<ctype.h>`头文件提供的宏定义来进条件分支判断。对于每一个ASCII码所代表的不同种类字符都有针对性很强的标准库函数可以直接调用,在提高效率的同时也增强了代码可移植性和易维护性。 ### 知识点拓展 - `getchar()` 函数每次都会返回下一个可用字符直到遇见终止符; - `<ctype.h>` 中不仅包含了对单个字符属性检测的功能,还提供了大小写字母转换等功能;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值