• JavaScript--数据结构与算法之列表


    3.1 列表的抽象数据类型定义
    列表:一组有序的数据。每个列表中的数据称为元素。在JavaScript中列表的元素可以是任意的数据类型。列表中保存的元素没有事先的限定,实际使用时的元素数量受到程序内存的限制。
    属性:
    listSize: 列表的元素个数
    pos: 列表的当前位置
    length: 返回列表中元素的个数
    方法:
    clear(): 清空列S表中的所有元素
    toString(): 返回列表的字符串形式
    getElement(): 返回当前位置的元素
    insert(): 现有元素后插入新元素
    append(): 在列表的末尾添加一个元素
    remove(): 从列表中移除元素
    front(): 从列表的当前位置移动到第一个位置
    end(): 从列表的当前位置移动到最后一个位置
    prev(): 当前位置后移一位
    next(): 当前位置前移一位
    currPos(): 返回列表的当前位置
    moveTo(): 将当前位置移动到指定位置

    创建List列表,及扩展属性方法:

     1 function List() {
     2   this.listSize = 0;
     3   this.pos = 0;
     4   this.dataStore = [];
     5   //面向对象方法不在初始化中,这里只初始化属性
     6   //this.clear = clear;
     7   //this.toString = toString;
     8   //this.insert = insert;
     9   //this.append = append;
    10   //this.remove = remove;
    11   //this.front = front;
    12   //this.end = end;
    13   //this.prev = prev;
    14   //this.currPos = currPos;
    15   //this.moveTo = moveTo;
    16   //this.length = length;
    17 }
    18 //append()方法在列表的末尾插入一个元素:
    19 List.prototype.append = function(element) {
    20   this.dataStore[this.listSize++] = element;
    21 }
    22 //插入的元素赋值给dataStore,同时改变对应的下标;
    23 
    24 //find()找到列表中所对应的元素:通过遍历dataStore中的元素,匹配元素是否相等,如果是返回对应的下标,如果不是返回-1;
    25 List.prototype.find = function(element) {
    26   for(var i = 0; i < dataStore.length; i++) {
    27     if(this.dataStore[i] == element) {
    28       return i;
    29     }
    30   }
    31   return -1;
    32 }
    33 
    34 //remove()移除列表中的元素:
    35 //首先通过find()方法把所要删除的元素找到,如果存在所要删除的元素,利用数组splice();方法删除,同时listSize列表元素个数减一,删除成功返回true;失败返回false;
    36 List.prototype.remove = function(element) {
    37   var findElement = this.find(element);
    38   if( findElement > -1) {
    39     this.dataStore.splice(findElement,1);
    40     this.listSize--;
    41     return true;
    42   }
    43   return false;
    44 }
    45 
    46 //length: 列表length,返回元素的个数
    47 List.prototype.length = function() {
    48   return this.listSize;
    49 }
    50 
    51 //toString()显示列表中的元素
    52 List.prototype.toString = function() {
    53   return this.dataStore;
    54 }
    55 
    56 //insert()项列表中插入一个元素:
    57 //接受两个参数,一个是插入的元素,一个是插入的位置。该方法使用find()方法找到对应的元素,通过判断该元素是否存在,如果不存在在进行插入操作,不存在则通过数组的splice()方法进行插入,同时改变list列表的元素个数。成功返回true,失败返回false;
    58 List.prototype.insert = function(element,after) {//插入元素,插入位置(从0开始)
    59   var insertPos = this.find(after);
    60   if(insertPos > -1) {
    61     this.dataStore.splice( insertPos+1,0,element );//pos+1数组下标从0开始
    62     this.listSize++;
    63     return true;
    64   }
    65   return false;
    66 }
    67 
    68 //clear()清空列表中的所有元素:
    69 //该方法通过delete删除dataStore数组,重新创建空的新数组,然后把list列表的元素个数,当前位置改为0;
    70 List.prototype.clear = function() {
    71   delete this.dataStore;
    72   this.dataStore = [];
    73   this.listSize = this.pos = 0;
    74 }
    75 
    76 //contains()判断给定值是否在list列表中
    77 //该方法和find()方法类似,contains方法包含返回true,不包含返回false,find方法查找到该元素,返回该元素的下标,不存在返回-1。
    78 List.prototype.contains = function(element) {
    79   for(var i = 0; i < this.dataSize.length; i++) {
    80     if( this.dataStore[i] == element ) {
    81       return true;
    82     }
    83   }  
    84   return false;
    85 }
  • 相关阅读:
    2017 ICPC 广西邀请赛1004 Covering
    2017 ICPC 广西邀请赛1005 CS Course
    2017-8-23 训练日记
    2017-8-22 训练日记
    2017-8-21 训练日记
    1034: [ZJOI2008]泡泡堂BNB
    1041: [HAOI2008]圆上的整点
    2017-8-19训练日记
    2017-8-18训练日记
    code force 424 A
  • 原文地址:https://www.cnblogs.com/intelwisd/p/7285263.html
Copyright © 2020-2023  润新知