当前位置: 首页 > news >正文

模块化网站建设 局域网wordpress改dz

模块化网站建设 局域网,wordpress改dz,企业网站建设论文5000,建设网站专业公司哪家好什么是栈栈是一种特殊的线性表#xff0c;只允许一端进行数据的插入和删除#xff0c;即先进后出原则。类似于弹夹先装进去的子弹后面出#xff0c;后放入的子弹先出。栈的底层原理栈是一种线性结构#xff0c;所以既能使用数组实现#xff0c;也能使用链表实现#xff0…什么是栈栈是一种特殊的线性表只允许一端进行数据的插入和删除即先进后出原则。类似于弹夹先装进去的子弹后面出后放入的子弹先出。栈的底层原理栈是一种线性结构所以既能使用数组实现也能使用链表实现我就采用数组的方法实现一下栈public class MyStack {public int[] elem;private static final int DEFAULT_CAPACITY 10;public MyStack() {elem new int[DEFAULT_CAPACITY];}//既能统计栈中存储多少个有效数据也可以作为存放元素的下标public int usedSize;//压栈public void push(int val) {//先判满如果满了要扩容if(isFull()) {elem Arrays.copyOf(elem, elem.length * 2);}elem[usedSize] val;usedSize;}private boolean isFull() {return usedSize elem.length;}//出栈public int pop() {//先判空如果栈为空抛出异常if(empty()) {throw new EmptyArrayException(栈为空);}int val elem[usedSize-1];usedSize--;return val;}private boolean empty() {return usedSize 0;}//查看栈顶元素public int peek() {if(empty()) {throw new EmptyArrayException(栈为空);}return elem[usedSize-1];}//获取栈中有多少元素public int getUsedSize() {return usedSize;} }使用数组的实现方式入栈只需要elem[usedSize] data和出栈只需要usedSize--的时间复杂度都是O1。如果使用单向链表采用头插法入栈和出栈只需要移动head头节点时间复杂度也是O(1);要是采用尾插法入栈和出栈入栈和出栈都需要从头节点出发走到尾巴才能完成元素的入栈或出栈时间复杂度为On).如果是双向链表那么一个节点即知道后继节点也知道前驱节点有头节点head也有尾节点tail采用头插法进行入栈和出栈只需要移动head头节点采用尾插法进行入栈和出栈也是一样只需要移动tail尾巴节点。栈的可能出栈顺序题目若入栈序列为1234进栈的过程中可以出栈则下面不可能的出栈序列是哪个A.1,4,3,2 B.2,3,4,1 C.3,1,4,2 D.3,4,2,1方法按题目给的入栈顺序结合选项加画图熟练以后不用画图A选项第一个出栈是1所以1进栈后出栈2进栈3进栈因为出栈的第二个是4所以23没有出栈4进栈。4出栈3出栈2出栈。所以A是可能的出栈序列B选项B选项第一个出栈的是2所以1进栈2进栈2出栈3进栈3出栈4进栈4出栈此时栈还剩11出栈。也是可能的出栈序列C选项你看C选项第一个出栈的是3所以123都进栈3再出栈它第二个出栈的是1但是此时栈顶元素是2所以这是不可能的出栈顺序D选项第一个出栈的是3所以要123都入栈了3是栈顶元素才能出栈接着4入栈4又出栈然后把栈中2出栈1出栈有关出栈顺序的oj题 https://www.nowcoder.com/practice/d77d11405cc7470d82554cb392585106?tpId13tqId11174rp1ru/activity/ojqru/ta/coding-interviews/question-rankingpublic class Solution {public boolean IsPopOrder(int [] pushA, int [] popA) {StackInteger stack new Stack();int index 0;//popA数组下标//遍历压栈pushA数组for (int i 0; i pushA.length; i) {stack.push(pushA[i]);//如果栈顶元素和popA[index]相等//并且要防止栈为空空指针异常和数组越界//使用循环可能连着多个相等while (!stack.empty() index popA.length stack.peek() popA[index]) {stack.pop();index;}}//如果是可能的出栈序列那么栈中的元素能全部匹配全部被弹出//如果栈不为空说明是不可能的出栈序列return stack.empty();} }中缀表达式转后缀表达式题目1中缀表达式23*6的后缀表达式题目2 中缀表达式23*5的后缀表达式中缀转后缀我们是加括号然后把操作符移到对应括号后面再去括号。同理中缀转前缀就是把操作符移到括号前面求后缀表达式/逆波兰表达式的计算结果力扣Oj: https://leetcode.cn/problems/evaluate-reverse-polish-notation/解决方法使用栈将数字放入栈中如果碰到操作符取出栈顶的2个元素第一个取出的放操作符右边第二个取出放操作符左边固定的计算完了再放入栈中直到遍历完该字符串数组此时栈中元素的值就是结果class Solution {public int evalRPN(String[] tokens) {//等会要进行运算类型用IntegerStackInteger stack new Stack();//遍历数组for(String x: tokens) {//判断是不是数字字符串if(! isOperation(x)) {//如果是数字字符串入栈stack.push(Integer.parseInt(x));//转为数字}else {//碰到操作符出栈2个数int num1 stack.pop();int num2 stack.pop();//根据不同操作字符进行运算,第一个弹出放操作符右边第二个放左边//运算完后重新入栈switch(x) {case :stack.push(num2 num1);break;case - :stack.push(num2 - num1);break;case *:stack.push(num2 * num1);break;case / :stack.push(num2 / num1);break;} }}//此时栈中元素就是运算结果return stack.pop();}private boolean isOperation(String x) {//字符串比较不能使用,是比较地址而不是比较值//字符串重写了Object类的equals()方法是比较值的if(x.equals() || x.equals(-) || x.equals(*) || x.equals(/)) {return true;//如果是操作符返回真}return false;//不是返回假} }
http://www.hkea.cn/news/14392418/

相关文章:

  • 刚做的网站 为啥搜不到织梦网站备份几种方法
  • 网站建设得步骤互联网服务行业有哪些工作
  • 网站模板整站资源建设三轮摩托车官方网站
  • 论吉林省网站职能建设天眼查企业入口免费
  • 阿里云虚拟主机网站wordpress 博客 主题
  • 企业建站的作用是什么seo与网站优化 pdf
  • 安徽省建设工程质量安全监督总站网站seo规范培训
  • 手机软件下载网站高大上的公司网站
  • 网站都是用什么编写的搜索引擎排名的三大指标
  • 咨询公司网站设计效果图网站哪个好
  • 电子工程网官网wordpress 4 优化
  • 网站改版合同wordpress 4.9.7 中文
  • 做网站项目团队口号太仓手机网站建设
  • 傻瓜式网站建设软件有哪些网页设计报价表
  • 黄金网站app视频域名 网址 网站名称
  • 营销型网站方案书数字营销工具
  • 只做女性的网站威海市网站建设
  • 辽宁网站建设电话百度企业网站建设
  • 建设互联网站的目的热门的网页设计工具有哪些
  • 上海网站推广找哪家成都展示型网站开发
  • 网站建设是前端的吗谁做的四虎网站是多少
  • 建站公司新闻资讯成都网络推广公司
  • 客户网站留言有用unity做网站的吗
  • 贵港有网站建设的公司吗北滘大良网站制作
  • wordpress 网站重置电商网站建设的步骤
  • 做首图的网站免费制作自己的网站
  • 网站开发,自定义首页显示响应式做的好的网站有哪些
  • 网络营销企业网站优化艺考有哪些专业
  • 保险公司网站策划西双版纳
  • 内蒙古城乡建设部网站首页wordpress页眉显示购物车