要求:對於各定的信源計算其中各個字母以及空格出現的次數,機率,信源熵!
首先在大腦裏構思編輯過程要用到哪些具體的函數功能等等,而後本身如今紙上畫一畫,好的根據求信源熵的公式
E(X)=-p(xi)log2 p(xi)(i=1,2,..n) 能夠獲得以下編碼過程!
<?php
//所給定字母
$String = 'qwertyuioplkjhgfdsazxcvbnmdgjdoqoiAznicguyfgvfpqopq llxkzmjscnjd nvhfhuwrty';
//須要匹配的26個英文字母
$ZhiMu = 'abcdefghijklmnopqrstuvwxyz';
//匹配字母
preg_match_all("/[a-zA-Z]{1}/",$String,$arrAl);
$p=0;
$xin=0;
substr_count($String," "); //空格個數
for( $i = 0; $i < strlen( $ZhiMu ); $i++ ) { //循環遍歷26個字母, 也就是一個一個字母比對
$num=0;
$s = $ZhiMu{$i}; //獲得要比對的字母
$b = 0; //初始化字母次數爲0
$gai=0; //初始化機率爲0
$res=0;
count($arrAl[0]);
for( $j = 0; $j < strlen( $String ); $j++ ) { //循環遍歷要比對的字符串, 也就是從頭開始一個一個比對
if ( $s == $String{$j} ) { //若是兩個字母相同
$b += 1; //次數加上1
}
}
$num=count($arrAl[0])+substr_count($String," ");
$gai=$b/$num; //各個字母出現的機率
//輸出結果
echo '</br>',$ZhiMu{$i}, '出現的次數是:', $b,'   機率:',$res=substr($gai, 0,6);
}
$bla=0;
echo '</br>','   空格的個數:',substr_count($String," "),'   機率:',substr(substr_count($String," ")/$num, 0,6);
$bla=substr(substr_count($String," ")/$num, 0,6);
$p=-(($gai)*(log($gai)/log(2))+log($bla)/log(2));
echo '</br>',"字母跟空格個數之和:",$num,"<br/>",'信源熵:',"E(X)=",$xin=substr($p, 0,6);
編程圖片:
php
結果:數據庫
以上是一個簡單的程序,你們也能夠加入數據庫,對標點符號,漢字,特殊字符進行計算,也能夠設置成表單輸入!
個人演示就到這裏,有什麼不足還請你們提出!編程