长为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

相关文章

hdu1496(用hash思想统计数目)

作为一个刚学hash的孩子,感觉这道题目很不错,灵活的运用的数组的下标。 解题步骤:如果用常规方法解,那么时间复杂度为O(n^4),肯定会超时,然后参考了网上的解题方法,将等式分成两个部分,a*x1^2+b*x2^2和c*x3^2+d*x4^2, 各自作为数组的下标,如果两部分相加为0,则满足等式; 代码如下: #include<iostream>#include<algorithm

usaco 1.2 Name That Number(数字字母转化)

巧妙的利用code[b[0]-'A'] 将字符ABC...Z转换为数字 需要注意的是重新开一个数组 c [ ] 存储字符串 应人为的在末尾附上 ‘ \ 0 ’ 详见代码: /*ID: who jayLANG: C++TASK: namenum*/#include<stdio.h>#include<string.h>int main(){FILE *fin = fopen (

flume系列之:查看flume系统日志、查看统计flume日志类型、查看flume日志

遍历指定目录下多个文件查找指定内容 服务器系统日志会记录flume相关日志 cat /var/log/messages |grep -i oom 查找系统日志中关于flume的指定日志 import osdef search_string_in_files(directory, search_string):count = 0

hdu4267区间统计

题意:给一些数,有两种操作,一种是在[a,b] 区间内,对(i - a)% k == 0 的加value,另一种操作是询问某个位置的值。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import

hdu4417区间统计

给你一个数列{An},然后有m次查询,每次查询一段区间 [l,r] <= h 的值的个数。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamRead

hdu3333区间统计

题目大意:求一个区间内不重复数字的和,例如1 1 1 3,区间[1,4]的和为4。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamReader;

实例:如何统计当前主机的连接状态和连接数

统计当前主机的连接状态和连接数 在 Linux 中,可使用 ss 命令来查看主机的网络连接状态。以下是统计当前主机连接状态和连接主机数量的具体操作。 1. 统计当前主机的连接状态 使用 ss 命令结合 grep、cut、sort 和 uniq 命令来统计当前主机的 TCP 连接状态。 ss -nta | grep -v '^State' | cut -d " " -f 1 | sort |

每日一题|牛客竞赛|四舍五入|字符串+贪心+模拟

每日一题|四舍五入 四舍五入 心有猛虎,细嗅蔷薇。你好朋友,这里是锅巴的C\C++学习笔记,常言道,不积跬步无以至千里,希望有朝一日我们积累的滴水可以击穿顽石。 四舍五入 题目: 牛牛发明了一种新的四舍五入应用于整数,对个位四舍五入,规则如下 12345->12350 12399->12400 输入描述: 输入一个整数n(0<=n<=109 ) 输出描述: 输出一个整数

Python脚本:TXT文档行数统计

count = 0 #计数变量file_dirs = input('请输入您要统计的文件根路径:')filename = open(file_dirs,'r') #以只读方式打开文件file_contents = filename.read() #读取文档内容到file_contentsfor file_content in file_contents:

C和指针:字符串

字符串、字符和字节 字符串基础 字符串就是一串零个或多个字符,并且以一个位模式为全0的NUL字节结尾。 字符串长度就是字符串中字符数。 size_t strlen( char const *string ); string为指针常量(const修饰string),指向的string是常量不能修改。size_t是无符号数,定义在stddef.h。 #include <stddef.h>