1. 程式人生 > >Javascript 小練習

Javascript 小練習


--------------------------要收穫別人五年才能收穫的東西,你就要做好準備,遭受別人五人所遭受的坎坷”
// -------------------------------*******************-------------------------------

/*寫一個函式,功能實現是告知你所選定的小動物的叫聲*/

// function vioce(animal) {
// switch (animal){
// case "dog":
// document.write("wang!wang!");
// return;
// case "cat":
// document.write("miao!miao!");
// return;
// case "fish":
// document.write("O~O~O~!");
// return;
// default:
// document.write("卡哇伊拉塞!");
// return
// }
// }

/*在網頁console裡執行vioce("dog")*/
//vioce("dog")

// -------------------------------*******************-------------------------------

/*寫一個函式,實現加法計數器*/

// function jia(a,b) {
// // document.write(a+b)
// // return a+b
// }

//add(5,7)


// -------------------------------*******************-------------------------------

// 定義一組函式 輸入數字 逆轉並輸出漢字形式

// function reverse() {
// var num = window.prompt('input');
// var str = '';
// for (var i = num.length - 1; i >= 0; i--) {
// str += transfer(num[i]);
// }
// document.write(str);
// }
//
//
// function transfer(content) {
// switch (content) {
// case "1":
// return '壹';
// case "2":
// return '倆';
// case "3":
// return '仨';
// }
// }

// -------------------------------*******************-------------------------------
//定義一個函式 實現一個階乘演算法 (找規律,找出口) (遞迴)

function mul(n) {
//思路 先找規律 求一個數的階乘 就是 n*(n-1)
// 找出口 當n=1 時 就知道結果
if (n == 1) {
return 1;
}
return n * mul(n - 1)
}
mul(5)

// -------------------------------*******************-------------------------------
//定義一個函式 實現斐波那契數列

<script type="text/javascript">
function fibonacci(n) {
var one = 1;    
var two = 1;    
for(var i = 3; i <= n; i++) {    //此處程式碼重點部分,用three累加前兩個數的和,也是斐波那契數列的精髓所在。
var three = one + two;      
one = two;      
two = three;      

}
if (n==1||n==2) {    //判斷n==1或2的情況下返回undefined
return one;
}
return three;       //最後返回three
}
console.log(fibonacci(2));
</script>





// -------------------------------*******************-------------------------------
[遞迴實現--斐波那契數列]

function box(m){
if(m==1||m==2){
return 1;
}
8 return box(m-1)+box(m-2);    //除去1和2的兩種情況,遞迴斐波那契數列一行程式碼就能搞定,但是遞迴效能是大大不如函式的。
}
alert(box(2));








// -------------------------------*******************-------------------------------
// 要求輸入一串低於10位的數字 純輸出這穿數字的中文大寫


function convertCurrency(money) {
//漢字的數字
var cnNums = new Array('零', '壹', '貳', '叄', '肆', '伍', '陸', '柒', '捌', '玖');
//基本單位
var cnIntRadice = new Array('', '拾', '佰', '仟');
//對應整數部分擴充套件單位
var cnIntUnits = new Array('', '萬', '億', '兆');
//對應小數部分單位
var cnDecUnits = new Array('角', '分', '毫', '釐');
//整數金額時後面跟的字元
var cnInteger = '整';
//整型完以後的單位
var cnIntLast = '元';
//最大處理的數字
var maxNum = 999999999999999.9999;
//金額整數部分
var integerNum;
//金額小數部分
var decimalNum;
//輸出的中文金額字串
var chineseStr = '';
//分離金額後用的陣列,預定義
var parts;
if (money == '') { return ''; }
money = parseFloat(money);
if (money >= maxNum) {
//超出最大處理數字
return '';
}
if (money == 0) {
chineseStr = cnNums[0] + cnIntLast + cnInteger;
return chineseStr;
}
//轉換為字串
money = money.toString();
if (money.indexOf('.') == -1) {
integerNum = money;
decimalNum = '';
} else {
parts = money.split('.');
integerNum = parts[0];
decimalNum = parts[1].substr(0, 4);
}
//獲取整型部分轉換
if (parseInt(integerNum, 10) > 0) {
var zeroCount = 0;
var IntLen = integerNum.length;
for (var i = 0; i < IntLen; i++) {
var n = integerNum.substr(i, 1);
var p = IntLen - i - 1;
var q = p / 4;
var m = p % 4;
if (n == '0') {
zeroCount++;
} else {
if (zeroCount > 0) {
chineseStr += cnNums[0];
}
//歸零
zeroCount = 0;
chineseStr += cnNums[parseInt(n)] + cnIntRadice[m];
}
if (m == 0 && zeroCount < 4) {
chineseStr += cnIntUnits[q];
}
}
chineseStr += cnIntLast;
}
//小數部分
if (decimalNum != '') {
var decLen = decimalNum.length;
for (var i = 0; i < decLen; i++) {
var n = decimalNum.substr(i, 1);
if (n != '0') {
chineseStr += cnNums[Number(n)] + cnDecUnits[i];
}
}
}
if (chineseStr == '') {
chineseStr += cnNums[0] + cnIntLast + cnInteger;
} else if (decimalNum == '') {
chineseStr += cnInteger;
}
return chineseStr;
}