手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >javascript写的一个链表实现代码
javascript写的一个链表实现代码
摘要:本来要用Array来保存数据的,没试过用JS来数据结构,就用JS来试试吧。JS效率真的很低一个链表装1000个对象浏览器就提示运行缓慢了。之...

本来要用Array来保存数据的,没试过用JS来数据结构,就用JS来试试吧。

JS效率真的很低一个链表装1000个对象浏览器就提示运行缓慢了。

之前觉得AJAX3D挺用前景的,现在看来还没有流行就要夭折了。用delphi开发的游戏人们都觉得太慢了,何况用JS。

下面是我实现的一个链表:

复制代码 代码如下:

/*@author eric

*@mail shmilyhe@163.com

*blog.csdn.net/shmilyhe

*/

<script>

function Student(no,name){

this.id=no;

this.name=name;

this.scores={chinese:0,math:0,english:0};

}

function List(){

this.head=null;

this.end=null;

this.curr=null;

}

List.prototype.add=function(o){

var tem={ob:o,next:null};

if(this.head){

this.end.next=tem;

this.end=tem;

}else{

this.head=tem;

this.end=tem;

this.curr=tem;

}

}

List.prototype.del=function(inde){

var n=this.head;

for(var i=0;i<inde;i++){

n=n.next;

}

n.next=n.next.next?n.next.next:null;

}

List.prototype.next=function(){

var te=null;

if(this.curr){

te=this.curr.ob; this.curr=this.curr.next;}

return te;

}

List.prototype.hasnext=function(){

if(this.curr.ob!=null)return true;

return false;

}

var list=new List();

for(var i=0;i<1000;i++){

list.add(new Student(i,'name'+i));

}

var i=0;

while(list.hasnext()){

document.writeln(list.next().name);

if(i==10){document.writeln('<br/>'); i=0;}

i++;

}

</script>

【javascript写的一个链表实现代码】相关文章:

javascript常用方法总结

javascript事件冒泡实例分析

javascript模拟评分控件实现方法

javascript用函数实现对象的方法

javascript制作的滑动图片菜单

javascript中DOM复选框选择用法实例

在JavaScript应用中使用RequireJS来实现延迟加载

浅谈javascript中的闭包

javascript实现树形菜单的方法

Javascript节点关系实例分析

精品推荐
分类导航