第四章栈(1)

一、Stack()类

function Stack(){ this.dataStore=[]; this.top=0; this.push=push; this.pop=pop; this.peek=peek; this.clear=clear; this.length=length; this.isEmpty=isEmpty; } function push(element){ this.dataStore[this.top++]=element; return this.top; } function pop(){ return this.dataStore[--this.top]; } function peek(){ return this.dataStore[this.top-1]; } function length(){ return this.top; } function clear(){ this.top=0; } function isEmpty(){ if(this.length()<=0){ return true; }else{ return false; } } //测试Stack类的实现 let s=new Stack(); s.push("Tom"); s.push("Jack"); s.push("Bryan"); console.log("length: " + s.length());//3 console.log(s.peek());//Bryan let popped = s.pop(); console.log("The popped element is: " + popped);//Bryan console.log(s.peek());//Jack s.push("Cynthia"); console.log(s.peek());//Cynthia s.clear(); console.log("length: " + s.length());//0 console.log(s.peek());//undefined s.push("Clayton"); console.log(s.peek());//Clayton

二、栈的应用

1.数制间的相互转换:假设想将数字n转换为以b为基数的数字,实现转换的算法如下
   (1) 最高位为 n % b,将此位压入栈
   (2) 使用 n/b代替n
   (3) 重复步骤1 和 2,直到 n 等于 0,且没有余数。
   (4) 持续将栈内元素弹出,直到栈为空,依次将这些元素排列,就得到转换后数字的字符串形式
function mulBase(num,base){ let s=new Stack(); do{ s.push(num%base); num=Math.floor(num /= base); }while(num>0); let converted=""; while(s.length()>0){ converted +=s.pop(); } return converted; } let num=31; let base=2; let newNum=mulBase(num,base); console.log(num+" converted to base "+base+" is "+newNum);//11111 num =125; base=8; newNum=mulBase(num,base); console.log(num+" converted to base "+base+" is "+newNum);//175

2.判断给定字符串是否是回文

function isPalindrome(word){ let s=new Stack(); for(let i=0;i<word.length;i++){ s.push(word[i]); } let rword=""; while(s.length()>0){ rword +=s.pop(); } if(word==rword){ return true; }else{ return false; } } let word="hello"; if(isPalindrome(word)){ console.log(word+" is a palindrome"); }else{ console.log(word+"is not a palindrome"); } word='racecar'; if(isPalindrome(word)){ console.log(word+" is a palindrome"); }else{ console.log(word+"is not a palindrome"); }

3.递归

function factorial(n){ if(n==0){ return 1; }else{ return n*factorial(n-1); } } function fact(n){ let s=new Stack(); while(n>1){ s.push(n--); } let product=1; while(s.length()>0){ product *=s.pop(); } return product; } console.log(factorial(6));//720 console.log(fact(6));//720

三、习题

1.栈可以用来判断一个算术表达式中的括号是否匹配。编写一个函数,该函数接受一个算术表达式作为参数,返回括号缺失的位置。下面是一个括号不匹配的算术表达式的例子:2.3 + 23 / 12 + (3.14159×0.24。
function signUp(stack,ele){ switch(ele){ case "{": case "[": case "(": stack.push(ele); break; case "}": case "]": case ")": let topEle=stack.pop(); console.log(stack.top); if((topEle=='{'&& ele=='}')||(topEle=='['&& ele==']')||(topEle=='('&& ele==')')){ console.log('ok'); }else{ console.log("括号不匹配"); return; } break; } } let stack=new Stack(); let str="2.3 + 23 / 12 + ( 3.14159 × 0.24 "; str=str.split(" "); for(let i=0;i<str.length;i++){ signUp(stack,str[i]); } if(!stack.isEmpty()){ console.log("括号不匹配"); }
全部评论

相关推荐

AFBUFYGRFHJLP:直接去美帝试试看全奖phd吧
点赞 评论 收藏
分享
秋招进行到现在终于能写总结了。完全没想到战线会拉这么长,过程会如此狼狈,不过更应该怪自己太菜了。好在所有的运气都用在了最后,也是有个去处。背景:双2本硕科班,无竞赛,本科一段研究所实习,硕士一段大厂暑期实习但无转正。技术栈是C++&nbsp;&amp;&nbsp;Golang,实习是客户端音视频(而且是鸿蒙端开发),简历两个C++项目一个Golang项目。主要投递岗位:后端,cpp软开,游戏服务端,测开,以及一些不拘泥于Java的岗位。从8月起总共投递123家公司,笔试数不清了,约面大约30家。offer/oc/意向:友塔游戏(第一个offer,面试体验很好,就是给钱好少南瑞继保(计算机科班点击就送(限男生),不...
乡土丁真真:佬很厉害,羡慕~虽然我还没有到校招的时候,也想讲一下自己的看法:我觉得不是CPP的问题,佬的背书双2,技术栈加了GO,有两段实习。投了123,面了30.拿到11个offer。这个数据已经很耀眼了。这不也是CPP带来的吗?当然也不止是CPP。至少来说在这个方向努力过的也会有好的结果和选择。同等学历和项目选java就会有更好的吗?我个人持疑问态度。当然CPP在方向选择上确实让人头大,但是我觉得能上岸,至于最后做什么方向,在我看来并不重要。至于CPP特殊,有岗位方向的随机性,java不是不挑方向,只是没得选而已。也希望自己以后校招的时候能offer满满
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务