欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript實(shí)現(xiàn)快速排序(自已編寫)

 更新時間:2012年12月19日 11:13:15   作者:  
用到j(luò)avascript的排序一組數(shù)字,js沒有直接的數(shù)字比較的函數(shù)可以調(diào)用,所以自己寫了一個快速排序,需要的朋友可以了解下

簡述
用到j(luò)avascript的排序一組數(shù)字,js沒有直接的數(shù)字比較的函數(shù)可以調(diào)用,所以自己寫了一個快速排序
知識點(diǎn):
1. 正則表達(dá)式提取正負(fù)數(shù)字的string
2. str 轉(zhuǎn)數(shù)字 放回列表
3. js的對象Sort類的聲明及定義
4. Sort類構(gòu)造函數(shù)、成員函數(shù)定義方式(prototype)
5. 快速排序算法
代碼

復(fù)制代碼 代碼如下:

<!DOCTYPE html>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />.
<html>
<title>Quick Sort</title>
<head>
<script type = "text/javascript">
/*************Get Number From Input***********/
function getNumList(){
var result = "";
var nums = document.getElementById('numbers').value;
var reg = /([-][1-9][0-9]*)|([1-9][0-9]*)/g;
var numStrList = nums.match(reg);
var numList = new Array();
if(numStrList != null){
for(var i = 0;i < numStrList.length;i++){
var intNumber = parseInt(numStrList[i]);
numList.push(intNumber);
}
}
return MainProgram(numList);
};

/*****************Main*************************/
function MainProgram(numList){
var sort = new Sort(numList);
var sortedList = sort.getSortedList();
if(sortedList == null)
document.getElementById('result').innerHTML = "WRONG INPUT";
else{
document.getElementById('result').innerHTML = sortedList.join(',');
}
}

/**************Sort Class***********************/
var Sort = function(list){
this.resultList = list;
};

Sort.prototype.Partition = function(start,end){
var baseValue = this.resultList[start];
var basePos = start;
for(var j = start + 1;j <= end;j++){
if(baseValue > this.resultList[j]){
basePos++; //move the base position
this.Swap(basePos,j);
}
}
// move the base value to the correct place , before are smaller , behind are bigger
this.Swap(start,basePos);
return basePos;
}

Sort.prototype.QuickSort = function(start,end){
if(start < end){
var basePos = this.Partition(start,end);
this.QuickSort(start,basePos - 1);
this.QuickSort(basePos + 1, end);
}
};

Sort.prototype.Swap = function(pos1,pos2){
var temp = this.resultList[pos1];
this.resultList[pos1] = this.resultList[pos2];
this.resultList[pos2] = temp;
}

Sort.prototype.getSortedList = function(){
this.QuickSort(0,this.resultList.length - 1);
return this.resultList;
};

</script>
</head>
<body>
<B> Quick Sort</B>
<br>
<br>
<input type= "text" id = 'numbers' value = '' />
<input type = 'button' value = "exec" onclick = 'getNumList()'/>
<br>
<br>
<B>SORTED LIST: <B> <b id = 'result'></b>
</body>
</html>

輸出:

相關(guān)文章

  • 你必須知道的JavaScript 中字符串連接的性能的一些問題

    你必須知道的JavaScript 中字符串連接的性能的一些問題

    每種程序語言中都會涉及到字符竄連接,而這個小小的字符竄連接問題很可能會影響到系統(tǒng)的整體性能,本文主要探討JavaScript中字符串連接的性能問題
    2013-05-05
  • javascript delete 使用示例代碼

    javascript delete 使用示例代碼

    javascript delete的一些技巧,主要是從對象中刪除一個屬性,或從數(shù)組中刪除一個元素。具體的使用方法,可以參考下面的代碼。
    2010-03-03
  • js的匿名函數(shù)使用介紹

    js的匿名函數(shù)使用介紹

    匿名函數(shù)的作用是創(chuàng)建一塊封閉區(qū)域,外面不能夠訪問里面的變量和方法,下面為大家介紹下什么是匿名函數(shù)及其如何使用
    2013-12-12
  • JS函數(shù)定義方式的區(qū)別介紹

    JS函數(shù)定義方式的區(qū)別介紹

    下面小編就為大家?guī)硪黄狫S函數(shù)定義方式的區(qū)別介紹。小編覺得挺不錯的,現(xiàn)在分享給大家,給大家一個參考。一起跟隨小編過來看看吧
    2016-03-03
  • 使用UglifyJS合并/壓縮JavaScript的方法

    使用UglifyJS合并/壓縮JavaScript的方法

    在UglifyJS入門中主要記錄了UglifyJS的安裝,配置。篇末在命令行中使用了一個簡單命令來壓縮一個JS文件。這篇以編程的方式去壓縮JS文件。即寫一個build.js文件,使用node命令執(zhí)行該文件
    2012-03-03
  • JavaScript的RequireJS庫入門指南

    JavaScript的RequireJS庫入門指南

    這篇文章主要介紹了JavaScript的RequireJS庫入門指南,RequireJS庫的人氣近來攀升很快,需要的朋友可以參考下
    2015-07-07
  • javascript開發(fā)技術(shù)大全-第3章 js數(shù)據(jù)類型

    javascript開發(fā)技術(shù)大全-第3章 js數(shù)據(jù)類型

    字符串類型(string) :由unicode字符、數(shù)字、標(biāo)點(diǎn)符號組成,在javascript中沒有char字符類型 ,即使只表示一個字符,也必須用到字符串
    2011-07-07
  • JavaScript的DOM事件詳解

    JavaScript的DOM事件詳解

    這篇文章主要為大家詳細(xì)介紹了JavaScript的DOM事件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • js中值類型和引用類型的區(qū)別介紹

    js中值類型和引用類型的區(qū)別介紹

    這篇文章介紹了js中值類型和引用類型的區(qū)別,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • 關(guān)于JSON的定義以及如何使用

    關(guān)于JSON的定義以及如何使用

    這篇文章主要介紹了關(guān)于JSON的定義以及如何使用,JSON 的名稱中雖然帶有JavaScript,但這是指其語法規(guī)則是參考JavaScript對象的,而不是指只能用于JavaScript語言,需要的朋友可以參考下
    2023-07-07

最新評論