Scala栈练习

Scala栈练习一、概念详情可参考文章:数据结构学习--栈(一)栈(stack)就像弹夹一样,是先入后出的有序列表栈(stack)是限制线性表中元素的插入和删除只能在线性表的同一端进行的一种特殊线性表。允许插入和删除的一端,为变化的一端,称为栈顶(Top),另一端为固定的一端,称为栈底(Bottom)。根据堆栈的定义可知,最先放入栈中元素在栈底,最后放入的元素在栈顶,而删除元素刚好相反,最后...

大数据 2021-04-26 PM 1170次 0条

Scala单向链表练习

Scala单向链表练习一、概念单向链表的定义可参考文章:数据结构学习--链表二、代码单向链表objectobject SingleLinkedListDemo01 { def main(args: Array[String]): Unit = { // 测试单向链表的添加和遍历 val heroNode1 = new HeroNode(1, "宋江"...

大数据 2021-04-25 AM 1261次 0条

数据结构学习--递归-八皇后问题(回溯法)

数据结构学习--递归-八皇后问题(回溯法)一、八皇后问题介绍八皇后问题,是一个古老而著名的问题,是回溯算法的典型案例。该问题是国际西洋棋棋手马克斯·贝瑟尔于1848年提出:在8×8格的国际象棋上摆放八个皇后,使其不能互相攻击,即:任意两个皇后都不能处于同一行、同一列或同一斜线上,问有多少种摆法。二、八皇后问题算法思路分析(1)第一个皇后先放第一行第一列(2)第二个皇后放在第二行第一列、然后判...

Java 2020-01-30 PM 1550次 0条

数据结构学习--递归-迷宫问题

数据结构学习--递归-迷宫问题迷宫问题代码实现public class MiGong { public static void main(String[] args) { //先创建一个二维数组,模拟迷宫 //地图 int[][] map = new int[8][7]; //使用1表示墙 //上下全部...

Java 2020-01-30 PM 1462次 0条

数据结构学习--递归简述

数据结构学习--递归简述一、递归应用场景看个实际应用场景,迷宫问题(回溯), 递归(Recursion)二、递归的概念简单的说:递归就是方法自己调用自己,每次调用时传入不同的变量,递归有助于编程者解决复杂的问题,同时可以让代码变得简洁。三、递归调用机制两个递归调用案例:(1)打印问题(2)阶乘问题使用图解方式说明递归调用机制代码示例public class RecursionTest { ...

Java 2020-01-30 PM 1445次 0条

数据结构学习--中缀表达式转换为后缀表达式

数据结构学习--中缀表达式转换为后缀表达式前言大家看到,后缀表达式适合计算机进行运算,但是人却不太容易写出来,尤其是表达式很长的情况下,因此在开发中,我们需要将中缀表达式转成后缀表达式。步骤1. 初始化两个栈:运算符栈s1和储存中间结果的栈s2; 2. 从左至右扫描中缀表达式; 3. 遇到操作数时,将其压s2; 4. 遇到运算符时,比较其与s1栈顶运算符的优先级; 4.1 如果s1为空,或栈...

Java 2020-01-30 AM 1907次 0条

数据结构学习--逆波兰计算器

数据结构学习--逆波兰计算器完成一个逆波兰计算器,要求完成如下任务:(1)输入一个逆波兰表达式(后缀表达式),使用栈 (Stack),计算其结果 (2)支持小括号和多位数整数,因为这里我们主要讲的是数据结构,因此计算器进行简化,只支持对整数的计算。思路分析:例如: (3+4)×5-6 对应的后缀表达式就是 3 4 + 5 × 6 - , 针对后缀表达式求值步骤如下:(1). 从左至右扫描,将...

Java 2020-01-29 PM 1306次 0条

数据结构学习--逆波兰表达式

数据结构学习--逆波兰表达式一、前缀表达式(1)前缀表达式又称波兰式,前缀表达式的运算符位于操作数之前 (2)举例说明: (3+4)×5-6 对应的前缀表达式就是 - × + 3 4 5 6前缀表达式的计算机求值从右至左扫描表达式,遇到数字时,将数字压入堆栈,遇到运算符时,弹出栈顶的两个数,用运算符对它们做相应的计算(栈顶元素和次顶元素),并将结果入栈;重复上述过程直到表达式最左端,最后运算...

Java 2020-01-29 PM 1481次 0条

数据结构学习--栈实现综合计算器(中缀表达式)

数据结构学习--栈实现综合计算器(中缀表达式)使用栈来实现综合计算器思路图解使用栈完成表达式的计算 思路通过一个 index 值(索引),来遍历我们的表达式如果我们发现是一个数字,就直接入数栈如果发现扫描到是一个符号, 就分如下情况3.1 如果发现当前的符号栈为 空,就直接入栈3.2 如果符号栈有操作符,就进行比较,如果当前的操作符的优先级小于或者等于栈中的操作符, 就需要从数栈中pop出...

Java 2020-01-28 PM 2078次 0条

数据结构学习--栈(一)

数据结构学习--栈(一)一、栈的一个实际需求请输入一个表达式计算式:[7*2*2-5+1-5+3-3] 点击计算【如下图】请问: 计算机底层是如何运算得到结果的? 注意不是简单的把算式列出运算,因为我们看这个算式 7 2 2 - 5, 但是计算机怎么理解这个算式的(对计算机而言,它接收到的就是一个字符串),我们讨论的是这个问题。-> 栈二、栈的介绍(1)栈的英文为(stack)(2...

Java 2020-01-28 PM 1378次 0条