长为10000的字符串,由a-z及A-Z组成,统计出其中出现频率最高的字母

2023-12-07 15:08

本文主要是介绍长为10000的字符串,由a-z及A-Z组成,统计出其中出现频率最高的字母,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

/*Author:shizhixin
Email:szhixin@gmail.com
Blog:http://blog.csdn.net/ShiZhixin
Date:Dec 14,2009
Function:长为10000的字符串,由a-z及A-Z组成,统计出其中出现频率最高的字母
算法思想:
声明一个长度为52的数组nCountTable,遍历一遍待查数组,对于其出现的任意字母charCurrent,将nCountTable[charCurrent-'a']++,最后遍历一下nCountTable,查找最大的。
Note:同学在面试时碰见这个题目,略感兴趣。这个算法是自己实现的,注意题目要求字符串中只包含a-z,A-Z,程序如有错误,或更好的实现算法,希来邮件告知,倍感高兴。
*/

#include "iostream.h"

//遍历一下nTable数组中最大的数,并返回其下标,n为数组大小
int GetMaxCount(int nTable[],int n)
{
 int max=0;
 int k=0;
 for (int i=0;i<n;i++)
 {
  if (nTable[i]>max)
  {
   max=nTable[i];
   k=i;
  }
 }
 return k;
}

void main()
{
 char* cpStr="httpblogcsdnnetShiZhixin";//待查找字符串,字符串中只包含a-z,A-Z
 int nCountTable[52]={0};//统计频率表
 int nCountTemp;//当前字符的ASCII
 do
 {
  nCountTemp=*cpStr;
  if (nCountTemp>='a')
  {
   nCountTemp-='a'-26;//a-z
  }
  else
  {
   nCountTemp-='A';//A-Z
  }
  nCountTable[nCountTemp]++;
  cpStr++;
 } while (*cpStr!='/0');

 int nMaxCount=GetMaxCount(nCountTable,52);//遍历频率表,查找出现频率最多的下标
 char cMax=nMaxCount;
 if (nMaxCount>=26)
 {
  cMax+='a'-26;//a-z
 }
 else
 {
  cMax+='A';//A-Z
 }
 cout<<"字符串中频率最多的字符是:"<<cMax<<" "<<"共有"<<nCountTable[nMaxCount]<<"个";
}

这篇关于长为10000的字符串,由a-z及A-Z组成,统计出其中出现频率最高的字母的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/466331

相关文章

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

SQL Server跟踪自动统计信息更新实战指南

《SQLServer跟踪自动统计信息更新实战指南》本文详解SQLServer自动统计信息更新的跟踪方法,推荐使用扩展事件实时捕获更新操作及详细信息,同时结合系统视图快速检查统计信息状态,重点强调修... 目录SQL Server 如何跟踪自动统计信息更新:深入解析与实战指南 核心跟踪方法1️⃣ 利用系统目录

C# $字符串插值的使用

《C#$字符串插值的使用》本文介绍了C#中的字符串插值功能,详细介绍了使用$符号的实现方式,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录$ 字符使用方式创建内插字符串包含不同的数据类型控制内插表达式的格式控制内插表达式的对齐方式内插表达式中使用转义序列内插表达式中使用

详解MySQL中JSON数据类型用法及与传统JSON字符串对比

《详解MySQL中JSON数据类型用法及与传统JSON字符串对比》MySQL从5.7版本开始引入了JSON数据类型,专门用于存储JSON格式的数据,本文将为大家简单介绍一下MySQL中JSON数据类型... 目录前言基本用法jsON数据类型 vs 传统JSON字符串1. 存储方式2. 查询方式对比3. 索引

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、

Python中反转字符串的常见方法小结

《Python中反转字符串的常见方法小结》在Python中,字符串对象没有内置的反转方法,然而,在实际开发中,我们经常会遇到需要反转字符串的场景,比如处理回文字符串、文本加密等,因此,掌握如何在Pyt... 目录python中反转字符串的方法技术背景实现步骤1. 使用切片2. 使用 reversed() 函

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

MySQL 获取字符串长度及注意事项

《MySQL获取字符串长度及注意事项》本文通过实例代码给大家介绍MySQL获取字符串长度及注意事项,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql 获取字符串长度详解 核心长度函数对比⚠️ 六大关键注意事项1. 字符编码决定字节长度2

在Linux终端中统计非二进制文件行数的实现方法

《在Linux终端中统计非二进制文件行数的实现方法》在Linux系统中,有时需要统计非二进制文件(如CSV、TXT文件)的行数,而不希望手动打开文件进行查看,例如,在处理大型日志文件、数据文件时,了解... 目录在linux终端中统计非二进制文件的行数技术背景实现步骤1. 使用wc命令2. 使用grep命令

Springboot3+将ID转为JSON字符串的详细配置方案

《Springboot3+将ID转为JSON字符串的详细配置方案》:本文主要介绍纯后端实现Long/BigIntegerID转为JSON字符串的详细配置方案,s基于SpringBoot3+和Spr... 目录1. 添加依赖2. 全局 Jackson 配置3. 精准控制(可选)4. OpenAPI (Spri