
作者:bake
圖說演算法使用JavaScript(三)

3-4題目:最常出現的字母
撰寫一個函數,傳入引數為一個字串,其輸出的結果會將該字串中出現頻率最高的字母輸出。
JS max_character.htm
const my_max = str =>{
const words = {}; //You can create a const object
for (let ch of str)
words[ch] = words[ch]+1 || 1;
let counter = 0;
let most = null;
for (let ch in words) {
if (words[ch] > counter){
counter = words[ch];
most = ch;
}
}
return most;
};
console.log(my_max("tomorrow"));
PHP max_character.php
//$my_str="不要在你的智慧中夾雜著傲慢。不要使你的謙虛新缺乏智慧。";
$my_str="Hello World! 你好世界!";
//$my_str="我為人人,人人為我";
//$my_str="gooddoog";
echo "原來的字串:".$my_str."<br>";
function mb_str_split($str){
//不分中英字串都可以切成陣列
return preg_split('/(?<!^)(?!$)/u',$str);
}
function get_most_str($str){
$arr = mb_str_split($str); //切字串成陣列
$len = count ($arr);
$my_count = 0;
for ($i=0 ; $i<=$len-1; $i++){
$str_count=substr_count($str,$arr[$i]);
//計算出現次數
if ($str_count>$my_count){
$my_count=$str_count;
$most = $arr[$i];
}
}
return [$most,$my_count];
}
$most_str= get_most_str($my_str);
echo "最大數為".$most_str[0]."=".$most_str[1]."<br>";
使用函數:
substr_count() 計算子字串在字串中出現的次數
3-5題目:判斷兩字是否相同 Anagrams
這個函數的功能是給定兩個包含相同數量的字母的單字或片語,並進行判斷所傳入的單字或片語是否相同的檢查函數。
JS anagrams.js
const compare = str =>{
const table ={}; //宣告一個table物件
for (let char of str.replace(/\w/g, "").toLowerCase())
table[char] = table[char]+1 || 1;
return table;
};
const anagrams = (strA, strB) =>{
const charA = compare(strA);
const charB = compare(strB);
if (Object.keys(charA).length !==Object.keys(charB).length)
return false;
for (let char in charA)
if (charA[char] !== charB[char]) return false;
return true;
};
console.log(anagrams("happy birthday", "happy birthday"));
console.log(anagrams("happyy birthday", "hhappy birthday"));
說明:
str.replace(/\w/g,"").toLowerCase();
\w 包含數字字母與底線,等同於[A-Za-z0-9_] 出處
PHP anagrams.php
$my_str_1="happy birthday";
//$my_str_1="大家好";
$my_str_2="hhhappybirthday";
//$my_str_2="happy birthday";
echo "字串_1:".$my_str_1."<br>";
echo "字串_2:".$my_str_2."<br>";
function mb_str_split($str){
//不分中英字串都可以切成陣列
return preg_split('/(?<!^)(?!$)/u',$str);
}
/*
$str_1_ar = mb_str_split($my_str_1);
$str_2_ar = mb_str_split($my_str_2);
$str_len_1 = count ($str_1_ar);
$str_len_2 = count ($str_2_ar);
$flag =($str_len_1 != $str_len_2) ;
$i=0;
if($flag==1){
echo "這兩個長度不同<br>";
}else{
while ($i<= $str_len_1-1){
$flag2=strcmp($str_1_ar[$i],$str_2_ar[$i]);
if($flag2==1){
echo "這兩個字母不同<br>";
break;
}
$i++;
}
}
*/
function my_anagrams ($str1, $str2){
$str_1_ar = mb_str_split($str1);
$str_2_ar = mb_str_split($str2);
$str_len_1 = count ($str_1_ar);
$str_len_2 = count ($str_2_ar);
$flag1 =($str_len_1 != $str_len_2) ;
$i=0;
$msg1="這兩個長度相同<br>";
$msg2="這兩個字母相同<br>";
if($flag1==1){
$msg1="這兩個長度不同<br>";
$msg2="這兩個字母不同<br>";
}
else{
while ($i<= $str_len_1-1){
$flag2=strcmp($str_1_ar[$i],$str_2_ar[$i]);
if($flag2==1){
$msg2="這兩個字母不同<br>";
}
$i++;
}//while
}//elseif
return [$msg1,$msg2];
}//function
$my_msg = my_anagrams($my_str_1,$my_str_2);
echo $my_msg[0];
echo $my_msg[1];
函數使用:
strcmp(str1,str2) 比較兩個字串(對大小寫敏感)
3-6題目:反向陣列 Reverse Array
將給定的陣列中的元素,由前往後排列方式,變更成由後往前的排列順序。例如給定原陣列的內容值為[1,2,3,4],則所撰寫的這個函數會回傳[4,3,2,1]‵.
JS reverse.js
const rev1 = dim =>{
for (let i=0; i <dim.length /2; i++){
const temp = dim[i];
dim[i] = dim[dim.length-1-i];
dim[dim.length-1-i]=temp;
}
return dim;
};
const rev2 = dim =>{
for (let i=0; i<dim.length/2; i++) {
[dim[i], dim[dim.length-1-i]] = [
dim[dim.length-1-i], dim[i]
];
}
return dim;
};
console.log("['a','e','i','o','u']反向陣列:",rev1(['a','e','i','o','u']));
console.log("[2,4,6,8,10]反向陣列:",rev2([2,4,6,8,10]));
PHP reverse.php
$my_arr_1=array("a","e","i","o","u");
$my_arr_2=array(2,4,6,8,10);
//$my_str_2="happy birthday";
echo "陣列_1:";
print_r($my_arr_1);
echo "<br>";
echo "陣列_2:";
print_r($my_arr_2);
$re_arr_1 = array_reverse($my_arr_1);
$re_arr_2 = array_reverse($my_arr_2);
echo "<br>";
echo "反陣列_1:";
print_r($re_arr_1);
echo "<br>";
echo "反陣列_2:";
print_r($re_arr_2);
函數使用:
array_reverse($arr) 以相反的順序傳回數組
圖說演算法使用JavaScript(二)

3-1題目:字串反轉(String Reversal)
撰寫一個函數,傳入的引數為一個字串,其輸出結果會將該字串以反轉的方式輸出。
JS String_Reversal.js
const reverse1 = str =>
str
.split("")
.reverse()
.join("")
const reverse2 = str =>{
let result = "";
for (let ch of str) result = ch +result;
return result;
};
console.log(reverse1("不要在你的智慧中夾雜著傲慢。不要使你的謙虛新缺乏智慧。"));
console.log(reverse2("一個人年輕的時候,不會思索,他將一事無成。"))
PHP String_Reversal.php
$my_str="不要在你的智慧中夾雜著傲慢。不要使你的謙虛新缺乏智慧。";
echo "原來的字串:".$my_str."<br>";
function my_reverse ($str){
$len = strlen($str);
$str_ar = str_split($str);
$str_ar = array_reverse($str_ar);
$str_ar = join($str_ar);
//echo $len;
return $str_ar;
}
$my_len=my_reverse($my_str);
$my_len = strrev($my_str);
//這兩個方法,中文反轉後都會出現亂碼。
使用函數
strlen($str) 傳回字串的長度
array_reverse($arr) 以相反的順序傳回陣列
join() 把陣列組合為一個字串
strrev 反轉字串
PHP 中文字串反轉會出現亂碼,需要做以下的判斷。

3-2題目:迴文Palindrome
所謂迴文是指由左唸到右或由又唸到左,字母排列順序都一樣的,例如以下的字串就是一個迴文:
"人人愛我!我愛人人"
JS palindrome.js
const isPalindrome = str =>
str
.split("")
.every((ch,index) => ch === str[str.length - 1 - index]);
console.log("[人人愛我!我愛人人] 這句話是否為迴文(palindrome)?",
isPalindrome("人人愛我!我愛人人"));
PHP palindrome.php
$my_str="不要在你的智慧中夾雜著傲慢。不要使你的謙虛新缺乏智慧。";
//$my_str="Hello World! 你好世界!";
//$my_str="我為人人,人人為我";
//$my_str="gooddoog";
echo "原來的字串:".$my_str."<br>";
function mb_str_split($str){
//不分中英字串都可以切成陣列
return preg_split('/(?<!^)(?!$)/u',$str);
}
$arr = mb_str_split($my_str);
print_r ($arr);
$len = count($arr); //計算字串數
$mid_len=floor($len/2); //取中間整數
echo "<br>-----<br>";
for ($i=0; $i<=$mid_len-1; $i++){
if($i==0)
$last=$len-1; //第一筆 頭-尾
else
$last=$len-1-$i;
//比對兩個字是否一樣,一樣就為0
$check_f = strcmp($arr[$i],$arr[$last]);
echo $arr[$i]."-".$arr[$last]."<br>";
if ($check_f ==0){
$flag="true";
continue;
}else{
$flag="false";
//break;
}
}
echo "<br>".$len."-".$mid_len."<br>";
echo "FLAG=".$flag;
?>
使用函數:
count() 傳回陣列中元素的數目
floor() 取中間整數
strcmp 比較兩個字串(對大小寫敏感)
3-3題目:整數反轉(Integer Reversal)
整數反轉的函數是只給定一個整數的引數,該函數會反轉該數字的順序。例如,原傳入字串為「12345」,則其輸入結果為「54321」。
JS inter_reversal.js
const rev = integer =>
Math.sign(integer)*parseInt(
integer
.toString()
.split("")
.reverse()
.join("")
);
console.log(rev(98754321));
console.log(rev(-987001200));
PHP integer_reversal.php
$my_int=-987001200;
//$my_int=987654321;
//print_r(str_split($my_int));
echo "原始的數字=".$my_int;
function integer_reversal ($int){
$minus=0;
$arr=str_split(strval($int));
$len = count($arr)-1;
//echo "<br>".$len;
for($i=$len; $i>=0; $i--){
if($arr[$i]=="-")
$minus=1; //偵測是否為負數
else
$re_arr[]=$arr[$i];
}
return [$re_arr,$minus]; //返回兩個數值
}
$my_re=integer_reversal($my_int);
echo "<br>";
$num=intval(join($my_re[0]));
if ($my_re[1]==1)
$num=$num*(-1);
echo "<br>反轉後數字=".$num;
使用函數:
strval() 函數用於取得變數的字串值