机器学习算法——信息熵信息熵(Entropy), b/ O* B5 {' l3 B4 k
信息是个很抽象的概念。我们常常说信息很多,或者信息较少,但却很难说清楚信息到底有多少。比如一本书中到底有多少信息量。直到 1948 年,香农(C. E. Shannon)提出了“信息熵”(shāng) 的概念,才解决了对信息的量化度量问题。熵的概念发展成为信息论、数据压缩等学科的基础,在很多科学研究的领域尤其是计算机科学中有着广泛的应用。0 W* ?; E5 Q$ ?( [: e/ h5 }1 t
实际上,一条信息的信息量大小和它的不确定性或存在概率有直接的关系。比如说,我们要搞清楚一件非常非常不确定的事,或是我们一无所知的事情,就需要了解大量的信息。相反,如果我们对某件事已经有了较多的了解,我们不需要太多的信息就能把它搞清楚。所以,从这个角度,我们可以认为,信息量的度量就等于不确定性的多少。一个系统越是有序,信息熵就越低;反之,一个系统越是混乱,信息熵就越高。因此可以认为信息熵是系统有序化程度的一个度量。 Shannon 借鉴了热力学的概念,把信息与其存在概率关联起来并称之为“信息熵”,并给出了计算信息熵的数学表达式: H = - ∑ Pi * log2 Pi0 h; c" K2 @) j8 H: g
9 E$ J/ [) F' Y1 o0 Y N假设有一个字符串要求它的信息熵,其中Pi是字符i出现的概率(该字符出现次数/所有字符数),然后将所有的Pi乘上取对数后的值log2 Pi后累加,最后取负,得到字符串的信息熵。3 u# v/ L' M, ]' q) a+ f
本题要求计算给定字符串按照每个字符统计的信息熵。 5 L$ J$ x1 h$ d7 L输入:一个字符串,请忽略所有非字母的字符(即只关注a-z, A-Z),且不区分字母的大小写。 + t- M% z1 @7 v/ p* L8 h! [' x提示:可以用StdIn.readAll()读入字符串的所有内容4 k& X4 p) H, ^5 {
输出:对应字符串的熵值,输出请用格式化输出("%4.2f\n") 1 h8 B, Y* c6 X6 z. T3 f& N
样例输入:To be or not To be,↵' J9 }7 B# ~7 g
that is the question↵6 p1 {( Z) r5 ~7 c& F3 c o
样例输出:" ~; |' y; D2 g/ W+ L