实验:输入一篇英文新闻,以“#”结束,统计其中a-z这26个字母各出现的次数和总字符个数。(不区分大小写)
代码如下:
- #include <iostream>
- using namespace std;
- int main() {
- char ch;
- char s_letter[26]={'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z'};
- char b_letter[26]={'A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z'};
- int num[26]={0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};
- for (int i = 1; i <= 10000; i++) {
- ch = cin.get();
- if(ch == '#')break;
- for(int j=0;j<=25;j++)
- {
- if(ch==s_letter[j] || ch==b_letter[j]) num[j]++;
- }
- }
- for(int i=0;i<=25;i++)
- {
- cout<<s_letter[i]<<"出现的个数为"<<num[i]<<endl;
- }
- }
(拓展)统计26个字母在一篇新闻中各自出现的频率。
代码如下:
- #include <iostream>
- using namespace std;
- int main() {
- char ch;
- char s_letter[26]={'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z'};
- char b_letter[26]={'A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z'};
- int num[26]={0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};
- float f_num[26]={0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};
- int Sum;
- for (int i = 1; i <= 10000; i++) {
- ch = cin.get();
- if(ch == '#')break;
- for(int j=0;j<=25;j++)
- {
- if(ch==s_letter[j] || ch==b_letter[j]) num[j]++;
- }
- }
- for(int i=0;i<=25;i++)
- {
- cout<<s_letter[i]<<"出现的个数为"<<num[i]<<endl;
- }
- for(int i=0;i<=25;i++)
- {
- Sum+=num[i]; //计算字母总数
- }
- for(int i=0;i<=25;i++)
- {
- f_num[i]=num[i]*(1.0)/Sum * 100; //计算字母出现的频率*100
- }
- for(int i=0;i<=25;i++)
- {
- cout<<s_letter[i]<<"出现的频率为";
- printf("%.3f",f_num[i]);//保留三位小数
- cout<<"%"<<endl;//输出频率为百分之几
- }
}



(拓展)英文新闻由文件输入,统计其中a-z这26个字母各出现的次数和总字符个数。(不区分大小写)
- #include <iostream>
- #include <fstream>
- #include <cassert>
- #include <string>
- #include<algorithm>
- #include<iomanip>
- using namespace std;
- int main()
- { char s_letter[26]={'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z'};
- char b_letter[26]={'A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z'};
- int num[26]={0};
- float f_num[26]={0};
- ifstream infile;
- int Sum=0;
- infile.open("C:\\Users\\yyz22\\Desktop\\news1.txt");//打开文件txt 根据自身需求更改绝对路径 注意是双反斜杠\\
- char ch;
- infile >> noskipws;//不跳过空格和换行
- while (!infile.eof())//循环直到文本末尾结束
- {
- infile>>ch;
- cout<<ch;
- for(int j=0;j<=25;j++)
- {
- if(ch==s_letter[j] || ch==b_letter[j]) num[j]++;//统计字母出现个数
- }
- }
- infile.close();
- cout<<endl;
- for(int i=0;i<=25;i++)
- {
- cout<<s_letter[i]<<"出现的个数为"<<num[i]<<endl;
- Sum= Sum + num[i]; //计算字母总数
- }
- cout<<"总数:"<<Sum<<"\n";
- for(int i=0;i<=25;i++)
- {
- f_num[i]=float(num[i])/Sum; //计算字母出现的频率
- }
- for(int i=0;i<=25;i++)
- {
- cout<<s_letter[i]<<"出现的频率为";
- cout<<fixed<<setprecision(6)<<f_num[i]*100;
- cout<<"%"<<endl;//输出频率为百分之几
- }
- }
总结:for循环处理ch=cin.get(); 解决了enter结束输入流的问题。分别用if判断是什么字符或者#结束。
--yyz 1806
2018.10.24
实验:输入一篇英文新闻,以“#”结束,统计其中a-z这26个字母各出现的次数和总字符个数。(不区分大小写)的更多相关文章
- golang统计出其中英文字母、空格、数字和其它字符的个数
方法一 通过ASCII码表判断并统计 package main import "fmt" func charactortype() { var s2 string = " ...
- 【Python】【demo实验18】【练习实例】【统计输入字符串中,数字的个数、英文字母的个数及其他符号的个数】
原题: 输入一行字符,分别统计出其中英文字母.空格.数字和其它字符的个数. (本题暂时不支持中文字符及汉字) 我的代码: #!/usr/bin/python # encoding=utf-8 # -* ...
- js控制文本框只能输入中文、英文、数字与指定特殊符号.
先在'' 里输入 onkeyup="value=value.replace(/[^\X]/g,'')" 然后在(/[\X]/g,'')里的 X换成你想输入的代码就可以了, 中文u4 ...
- 限制HTML的input只能输入数字、英文、汉字...
限制HTML的input只能输入数字.英文.汉字... 关键词:正则表达式, JavaScript, HTML, input 常用HTML正则表达式1.只能输入数字和英文的:<input onk ...
- (js) 输入框只能输入中文、英文、数字、@符号和.符号
只能输入中文.英文.数字.@符号和.符号<input type="text" onkeyup="value=value.replace(/[^\a-\z\A-\Z0 ...
- C++语言,统计一篇英文文章中的单词数(用正则表达式实现)
下面的例子展示了如何在C++11中,利用regex_search()统计一篇英文文章中的单词数: #include <iostream> #include <regex> #i ...
- JS 控制文本框只能输入中文、英文、数字与指定特殊符号
想做姓名输入的js判断是否是中文,但是网上找的很多是源于一篇文章的,判断中文的正则式不对,后来找到一个可以准确判断了,但是是监测里面有中文的就行,跟我想要的只能输入中文的意思相左,所以又找了下面的 J ...
- js控制文本框仅仅能输入中文、英文、数字与指定特殊符号
JS 控制文本框仅仅能输入数字 <input onkeyup="value=value.replace(/[^0-9]/g,'')"onpaste="value=v ...
- Java Nested Classes(内部类~第一篇英文技术文档翻译)
鄙人最近尝试着翻译了自己的第一篇英文技术文档.Java Nested Classes Reference From Oracle Documentation 目录 嵌套类-Nested Classes ...
随机推荐
- ts问题处理(2): 'Promise' only refers to a type, but is being used as a value here.
error TS2585: 'Promise' only refers to a type, but is being used as a value here. Do you need to cha ...
- Scrapy基本命令
全局命令,不用在项目中运行fetch:爬取网页,不依赖爬虫项目直接爬网页信息,并显示爬取过程scrapy命令格式:scrapy 命令名 --参数,可能通过--控制,例如:scrapy fetch -h ...
- 第 8 章 容器网络 - 055 - 创建 macvlan 网络
1.创建 macvlan 网络 在 host1 和 host2 中创建 macvlan 网络 mac_net1: docker network create -d macvlan --subnet=1 ...
- fMRI在认知心理学上的研究
参考:Principles of fMRI 1 问题: 1. fMRI能做什么不能做什么? 第一周:fMRI简介,data acquisition and reconstruction 大致分为两类: ...
- 判断一个点在多边形的内部C++
/* 原理: 将测试点的Y坐标与多边形的每一个点进行比较, ** 会得到测试点所在的行与多边形边的所有交点. ** 如果测试点的两边点的个数都是奇数个, ** 则该测试点在多边形内,否则在多边形外. ...
- Lab 6-1
LABS The goal of the labs for this chapter is to help you to understand the overall functionality of ...
- LeetCode--020--括号匹配
题目描述: 给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效. 有效字符串需满足: 左括号必须用相同类型的右括号闭合. 左括号必须以正确的顺序闭合. 注意空 ...
- 20170821xlVBA隐藏空行
Sub HideBlankRowsBetweenUsedRange() Dim URows As Range, i As Long, EndRow As Long With ActiveSheet E ...
- Elasticsearch SQL
es sql是一个X-pack组件 ,允许对es执行类似sql的查询,可以将Elasticsearch SQL理解为一个编译器,既能理解es,又能理解sql.可以通过利用es,实施大规模实时读取和处理 ...
- Python基础之文件的初识函数
初识函数函数定义:定义一个事情或者功能. 等到需要的时候直接去用就好了了. 那么这里定义的东西就是一个函数即函数: 对代码块和功能的封装和定义1.1常用形式: def 函数名(): 函数体1.2 函数 ...