首页 > 编程语言 > 详细

数据结构(Javascript版)

时间:2017-09-18 00:06:44      阅读:254      评论:0      收藏:0      [点我收藏+]

正在学习数据结构,学的是C语言版的,把里面的例子用Javascript重写了一遍,如果有什么错误的话欢迎提出(持续更新)。

一、线性表

  1. 一般线性表合并:

    

 1  function addList(la,lb){
 2             var arrA=[],arrB=[];    //声明两个线性表
 3             
 4             //获取输入值
 5             arrA=la.value.split(‘,‘).map(function(item){return parseInt(item);});
 6             arrB=lb.value.split(‘,‘).map(function(item){return parseInt(item);});
 7             
 8             for(let i=0;i<arrB.length;i++){//取arrB中的第i个数字与arrA比较
 9                 for(var j=0;j<arrA.length;j++){
10                     if(arrB[i]==arrA[j]){
11                         break;
12                     }
13                 }
14                 if(j==arrA.length){//如果arrA中不存在arrB[i]将arrB[i]插入arrA中
15                     arrA.push(arrB[i]);
16                   
17                 }
18             }
19             
20             return arrA.join(‘,‘);
21         }

 

    2.有序线性表合并:

      

 1 function merge(la,lb){
 2             var arrA=la.value.split(‘,‘).map(function(item){return parseInt(item);});
 3             var arrB=lb.value.split(‘,‘).map(function(item){return parseInt(item);});
 4             var arrC=[],i=0,j=0;//arrC为合并后数组
 5             while((i<arrA.length)&&(j<arrB.length)){//当其中一个表遍历完则跳出循环
 6                 
 7                 if(arrA[i]<=arrB[j]){//依次摘取两表中较小的数插入到arrC中
 8                     
 9                     arrC.push(arrA[i]);
10                     i++;
11                 }else{
12                     console.log(‘b‘)
13                     arrC.push(arrB[j]);
14                     j++;
15                 }
16             }
17           
18             while(i<arrA.length){//arrB已遍历完,将arrA剩下的依次插入到arrC中
19                 arrC.push(arrA[i]);
20                 i++;
21             }
22             while(j<arrB.length){//arrA已遍历完,将arrB剩下的依次插入到arrC中
23                 arrC.push(arrB[j]);
24                 j++;
25             }
26             return arrC.join(‘,‘);
27          }

二、栈和队列:

  1.数制转换:

    

function transform(n,d){//输入十进制数n和需要转换的进制d
           var stack=[];//声明一个数组模拟栈
           while(n){    //每次将n%d入栈,再将n替换成n/d
               var m;
               if(d===16){//如果是16进制进行匹配
                   
                   switch(n%d){
                       case 10:m=‘a‘;break;
                       case 11:m=‘b‘;break;
                       case 12:m=‘c‘;break;
                       case 13:m=‘d‘;break;
                       case 14:m=‘e‘;break;
                       case 15:m=‘f‘;break;
                       default:m=n%d;break;
                   }
                   
               }else{
                   m=n%d;
               }
               stack.push(m);
               n=Math.floor(n/d);    //javascript中‘/’为除法运算,并非取整
           }
           
           return stack.reverse().join(‘‘);
       }

  2.括号匹配:

    

 1 function check(str){//传入需要检测的字符串
 2         var flag=1,stack=[];
 3 
 4         for(var i=0;i<str.length;i++){遍历字符串,检测每一个字符
 5           
 6           switch(str[i]){
 7             case ‘[‘:  
 8             case ‘(‘:
 9             case ‘{‘:stack.push(str[i]);break;//如果是[、(、{则入栈
10              //如果是]、)、}中的任意一个则判断栈顶元素是否与之匹配
11              //如果匹配则将栈顶元素出栈,否则报错,将flag设为0
12             case ‘)‘:if(stack[stack.length-1]==‘(‘){
13             
14               stack.pop();
15               break;
16             }else{
17               flag=0;
18               break;
19             };
20             case ‘]‘:if(stack[stack.length-1]==‘[‘){ //如果不于栈顶元素相匹配则错误
21               stack.pop();
22               break;
23             }else{
24               flag=0;
25               break;
26             };
27             case ‘}‘:if(stack[stack.length-1]==‘{‘){
28               stack.pop();
29               break;
30             }else{
31               flag=0;
32               break;
33             }
34           }
35 
36           if(!flag){break;};
37         }
38 
39         return flag;
40        }

 

数据结构(Javascript版)

原文:http://www.cnblogs.com/cjw-ryh/p/7538565.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!