问题描述
- C++编程 算法 求助!!!
-
C++编程 算法 求助!!!
c++代码编程出现频率
在一篇英文文章中,输入一个字母,请输出与该字母一起出现频率最高的三个字母。
如:输入s,可能和s一起出现频率最高的就是t,e.....
想知道算法!!!如果可以,可以给个代码作为参考吗?非常谢谢
解决方案
没问题,采纳了就写给你。
解决方案二:
求一篇英文文章中各个字母出现的频率,不区分大小写.
思路:
(1)首先定义一个数组freArray= new int[26],存放每个单词的出现频率.
(2)读取该篇文章到内存中,并形成一个字符数组.
(3)遍历该字符数组
----首先判断被遍历到字符c的ascii值是否大于'A'而且小于'Z',如果是,则freArray[c-'A']++
----然后判断被遍历到字符c的ascii值是否大于'a'而且小于'z',如果是,则freArray[c-'a']++
(4)然后输出freeArray中各个字母的统计值.
实现代码(Java):
package com.test.test;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
public class ComputeCharFrequency {
/**
* Compute the frequencies of letter occurrence
*
* @param args
*/
public static void main(String[] args) {
int[] freArray = new int[26];
char[] charArray = loadCharArrayFromFileName("c:/article.txt");
computeFrequency(freArray, charArray);
for (int i = 0; i < freArray.length; i++) {
System.out.println(((char) ('a' + i)) + ":" + freArray[i]);
}
}
public static void computeFrequency(int[] freArray, char[] charArray) {
for (int i = 0; i < charArray.length; i++) {
if (charArray[i] >= 'A' && charArray[i] <= 'Z') {
freArray[charArray[i] - 'A']++;
}
if (charArray[i] >= 'a' && charArray[i] <= 'z') {
freArray[charArray[i] - 'a']++;
}
}
}
/**
* read a text file's content to a Char Array
* @param name
* @return Char Array
*/
public static char[] loadCharArrayFromFileName(String name) {
char[] charArray = new char[50000];
File file = new File(name);
FileReader fr = null;
try {
fr = new FileReader(file);
fr.read(charArray);
return charArray;
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
try {
fr.close();
} catch (IOException e) {
e.printStackTrace();
}
}
return null;
}
}
解决方案三:
我给你百度的,是类似这样的么,你百度是没有这类题吗??
解决方案四:
楼上理解楼主的意思了,,,,,,
时间: 2024-12-29 01:43:07