代码如下:

  1. #include <iostream>
  2. using namespace std;
  3. int main() {
  4. char ch;
  5. 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'};
  6. 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'};
  7. 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};
  8. for (int i = 1; i <= 10000; i++) {
  9. ch = cin.get();
  10. if(ch == '#')break;
  11. for(int j=0;j<=25;j++)
  12. {
  13. if(ch==s_letter[j] || ch==b_letter[j]) num[j]++;
  14. }
  15. }
  16. for(int i=0;i<=25;i++)
  17. {
  18. cout<<s_letter[i]<<"出现的个数为"<<num[i]<<endl;
  19. }
  20. }

(拓展)统计26个字母在一篇新闻中各自出现的频率。

代码如下:

  1. #include <iostream>
  2. using namespace std;
  3. int main() {
  4. char ch;
  5. 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'};
  6. 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'};
  7. 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};
  8. 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};
  9. int Sum;
  10. for (int i = 1; i <= 10000; i++) {
  11. ch = cin.get();
  12. if(ch == '#')break;
  13. for(int j=0;j<=25;j++)
  14. {
  15. if(ch==s_letter[j] || ch==b_letter[j]) num[j]++;
  16. }
  17. }
  18. for(int i=0;i<=25;i++)
  19. {
  20. cout<<s_letter[i]<<"出现的个数为"<<num[i]<<endl;
  21. }
  22. for(int i=0;i<=25;i++)
  23. {
  24. Sum+=num[i]; //计算字母总数
  25. }
  26. for(int i=0;i<=25;i++)
  27. {
  28. f_num[i]=num[i]*(1.0)/Sum * 100; //计算字母出现的频率*100
  29. }
  30. for(int i=0;i<=25;i++)
  31. {
  32. cout<<s_letter[i]<<"出现的频率为";
  33. printf("%.3f",f_num[i]);//保留三位小数
  34. cout<<"%"<<endl;//输出频率为百分之几
  35. }

}

(拓展)英文新闻由文件输入,统计其中a-z这26个字母各出现的次数和总字符个数。(不区分大小写)

  1. #include <iostream>
  2. #include <fstream>
  3. #include <cassert>
  4. #include <string>
  5. #include<algorithm>
  6. #include<iomanip>
  7. using namespace std;
  8. int main()
  9. { 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'};
  10. 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'};
  11. int num[26]={0};
  12. float f_num[26]={0};
  13. ifstream infile;
  14. int Sum=0;
  15. infile.open("C:\\Users\\yyz22\\Desktop\\news1.txt");//打开文件txt 根据自身需求更改绝对路径 注意是双反斜杠\\
  16. char ch;
  17. infile >> noskipws;//不跳过空格和换行
  18. while (!infile.eof())//循环直到文本末尾结束
  19. {
  20. infile>>ch;
  21. cout<<ch;
  22. for(int j=0;j<=25;j++)
  23. {
  24. if(ch==s_letter[j] || ch==b_letter[j]) num[j]++;//统计字母出现个数
  25. }
  26. }
  27. infile.close();
  28. cout<<endl;
  29. for(int i=0;i<=25;i++)
  30. {
  31. cout<<s_letter[i]<<"出现的个数为"<<num[i]<<endl;
  32. Sum= Sum + num[i]; //计算字母总数
  33. }
  34. cout<<"总数:"<<Sum<<"\n";
  35. for(int i=0;i<=25;i++)
  36. {
  37. f_num[i]=float(num[i])/Sum; //计算字母出现的频率
  38. }
  39. for(int i=0;i<=25;i++)
  40. {
  41. cout<<s_letter[i]<<"出现的频率为";
  42. cout<<fixed<<setprecision(6)<<f_num[i]*100;
  43. cout<<"%"<<endl;//输出频率为百分之几
  44. }
  45. }

总结:for循环处理ch=cin.get(); 解决了enter结束输入流的问题。分别用if判断是什么字符或者#结束。

 --yyz 1806

2018.10.24

实验:输入一篇英文新闻,以“#”结束,统计其中a-z这26个字母各出现的次数和总字符个数。(不区分大小写)的更多相关文章

  1. golang统计出其中英文字母、空格、数字和其它字符的个数

    方法一 通过ASCII码表判断并统计 package main import "fmt" func charactortype() { var s2 string = " ...

  2. 【Python】【demo实验18】【练习实例】【统计输入字符串中,数字的个数、英文字母的个数及其他符号的个数】

    原题: 输入一行字符,分别统计出其中英文字母.空格.数字和其它字符的个数. (本题暂时不支持中文字符及汉字) 我的代码: #!/usr/bin/python # encoding=utf-8 # -* ...

  3. js控制文本框只能输入中文、英文、数字与指定特殊符号.

    先在'' 里输入 onkeyup="value=value.replace(/[^\X]/g,'')" 然后在(/[\X]/g,'')里的 X换成你想输入的代码就可以了, 中文u4 ...

  4. 限制HTML的input只能输入数字、英文、汉字...

    限制HTML的input只能输入数字.英文.汉字... 关键词:正则表达式, JavaScript, HTML, input 常用HTML正则表达式1.只能输入数字和英文的:<input onk ...

  5. (js) 输入框只能输入中文、英文、数字、@符号和.符号

    只能输入中文.英文.数字.@符号和.符号<input type="text" onkeyup="value=value.replace(/[^\a-\z\A-\Z0 ...

  6. C++语言,统计一篇英文文章中的单词数(用正则表达式实现)

    下面的例子展示了如何在C++11中,利用regex_search()统计一篇英文文章中的单词数: #include <iostream> #include <regex> #i ...

  7. JS 控制文本框只能输入中文、英文、数字与指定特殊符号

    想做姓名输入的js判断是否是中文,但是网上找的很多是源于一篇文章的,判断中文的正则式不对,后来找到一个可以准确判断了,但是是监测里面有中文的就行,跟我想要的只能输入中文的意思相左,所以又找了下面的 J ...

  8. js控制文本框仅仅能输入中文、英文、数字与指定特殊符号

    JS 控制文本框仅仅能输入数字 <input onkeyup="value=value.replace(/[^0-9]/g,'')"onpaste="value=v ...

  9. Java Nested Classes(内部类~第一篇英文技术文档翻译)

    鄙人最近尝试着翻译了自己的第一篇英文技术文档.Java Nested Classes Reference From Oracle Documentation 目录 嵌套类-Nested Classes ...

随机推荐

  1. str_replace 批量查找替换字符串

    <?php $str = 'I Love You!'; $str = str_replace('o','O',$str,$count); echo $str.PHP_EOL; // I LOve ...

  2. How to Get the Function Code in R

    http://fhqdddddd.blog.163.com/blog/static/1869915420104111031148/ http://blog.sina.com.cn/s/blog_61f ...

  3. 学习笔记3—matlab中load特殊用法

    1.在matlab中 ,infro.mat中存有很多子矩阵(比如:mean_FA.mat, mean_e1.mat和 mean_e2.mat),调出某一个矩阵时,命令行为:load([path,'\' ...

  4. 解决UnicodeEncodeError。python的docker镜像增加locale 中文支持

    用pandas的pd.read_excel()打开中文名的xlsx,报错,本来以为是xlrd的问题后来发现,是open()函数就报错: “UnicodeEncodeError: 'ascii' cod ...

  5. JAVA基础知识总结:十九

    一.多线程使用过程中的临界资源问题 1.临界资源:被多个线程同时访问的资源 临界资源产生的原因:有多个线程同时访问一个资源的时候,如果一个线程在取值的过程中,时间片又被其他的线程抢走了,临界资源问题就 ...

  6. ThinkPHP 日志(如何学好一门技术,教学视频和文档的优缺)

    ThinkPHP 日志(如何学好一门技术,教学视频和文档的优缺) 一.总结 一句话总结:教学视频中介绍的只是基础的最常用的使用,那些不常用的那些视频里面都不会介绍,因为需求小,所以还是需要好好去把参考 ...

  7. Android SDK无法更新的解决方法

    一.说明: Android 更新sdk时访问google很慢,有时连接不上,可利用国内的某些镜像网站实现Android SDK在线更新. 二.解决方法: 在SDK Manager -> tool ...

  8. Learn Python3 the hard way 第二天总结 命令行(2)

    复制文件 命令:cp含义:很简单,就是把一个文件复制成一个新文件而已.使用 cp -r命令可以复制一些包含文件的目录 移动文件 命令:mv含义:对文件进行"rename". 查看文 ...

  9. HTML 第十一章总结

    # 第十一章总结:本章的标题为:layout and positioning Arranging Element##前言:这一章节,通过已经知道的 box model 的概念,进行讲述关于 layou ...

  10. 雷林鹏分享:XML 元素

    XML 元素 XML 文档包含 XML 元素. 什么是 XML 元素? XML 元素指的是从(且包括)开始标签直到(且包括)结束标签的部分. 一个元素可以包含: 其他元素 文本 属性 或混合以上所有. ...