统计只有小写字母的字符串中字母的个数,并输出最大字母的个数的简单方法

思路:a~z二十六个字母在ascll码是连续的,定义数组count[26] ,下标i,让下标 i = ch - ‘a’,如果ch = a , count[0]++,记录的是a字母出现的个数,依次类推。只需要遍历一遍字符串,就可以把字符串的字母出现次数统计出来。

#include <stdio.h>

int main(int argc,char *argv[])
{
	int count[26] = {0};
	char str[100];
	char max_ch = 'a';
	int i = 0 , max = 0;

	printf("please enter the str: ");
	scanf("%s",str);
	
	//使用查表法统计 count[0] 用来统计a count[1]统计b .....
	//a~z 自然有序  如果 str[i]='a',则str[i] - 'a' = 0 ,a对应的下标为0
	//使用三目运算符把代码写成一行 ? :
	while(str[i] != '\0')	
		++count[str[i]-'a'] > max ? max = count[str[i]-'a'] , max_ch = str[i++] : i++;

	/*  拆分以上三目运算符等价以下代码
	   count[str[i]-'a']++;
	   if(count[str[i]-'a'] > max)
	   {
			max = count[str[i]-'a'];
			max_ch = str[i];
	   }
		i++;
	*/  	
	
	i = 0 ;
	while(26>i)
		printf("%c --> %d\n",(char)('a'+i),count[i++]);//打印统计结果

	printf("max_ch = %c --> %d\n",max_ch,max);

	return 0;

}

windows VC6的运行效果:

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

boonion

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值