Java 数据结构与算法1——几个经典算法面试题

简介

本文会介绍十大常用算法,二分查找(非递归)、分治、动态规划、贪心、KMP、马踏棋盘等

先看几个经典算法面试题

  1. 字符串匹配问题
    1)有一个字符串 str1="“硅硅谷尚硅谷你尚硅尚硅谷你尚硅谷你尚硅你好”",和一个子串 str2=“尚硅谷你尚硅你”
    2)现在要判断str1是否含有str2,如果存在,就返回第一次出现的位置,如果没有,则
    返回-1
    3)要求用最快的速度来完成匹配
    4)你的思路是什么?
    思路一:暴力匹配,简单、效率低
    思路二:KMP算法,部分匹配表

  2. 汉诺塔游戏
    请完成汉诺塔游戏的代码:
    要求:
    1)将A塔的所有圆盘移动到C塔。并且规定,
    2)在小圆盘上不能放大圆盘,
    3)在三根柱子之间一次只能移动一个圆盘
    在这里插入图片描述
    思路:分治算法

  3. 八皇后问题,是一个古老而著名的问题,是回溯算法的典型案例
    该问题是国际西洋棋棋手马克斯·贝瑟尔于1848年提出:在8×8格的国际象棋上摆放八个皇后,使其不能互相攻击,即:任意两个皇后都不能处于同一行、同一列或同一斜线上,问有多少种摆法。
    在这里插入图片描述
    思路:回溯算法。高斯认为有76种,图论的方法有92种。

  4. 马踏棋盘算法介绍和游戏演示
    1)马踏棋盘算法也被称为骑士周游问题
    2)将马随机放在国际象棋的8×8棋盘
    Board[0~7][0~7]的某个方格中,马按走棋规则(马走日字)进行移动。要求每个方格只进入一次,走遍棋盘上全部64个方格
    3)游戏演示: http://www.4399.com/flash/146267_2.htm
    思路:图的深度优化遍历算法(DFS) +贪心算法优化

在学习算法之前,搞定数据结构!

数据结构分两大类,线性结构(栈、队列、链表)和非线性结构(图和树)。
接下来要学习的内容如下表所示:

学习内容案例
数据结构和算法介绍一个五子棋程序介绍
稀疏sparsearray数组数组压缩和解压
队列场景展示及数组模拟
链表单、双链表及应用实例
栈应用场景及实例
递归递归场景
排序八大排序算法
算法复杂度时间与空间复杂度
查找算法线性、二分、插值、斐波那契
哈希表原理、实践
二叉树、顺序存储、线索化
树实际应用堆排序、赫夫曼树及编码、二叉排序树、平衡二叉
多路查找二叉树与B树、分治算法
深度优先
程序员10大算法二叉、分治、动态规划、KMP、贪心、普里姆、克鲁斯卡尔、迪杰斯特拉、弗洛伊德、马踏棋盘

学习步骤:应用场景->数据结构或算法->剖析原理->分析实现步骤(图解)->代码实现

接下来会陆续更新学习笔记~~~

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
1.栈和队列的共同特点是(只允许在端点处插入和删除元素) 4.栈通常采用的两种存储结构是(线性存储结构和链表存储结构) 5.下列关于栈的叙述正确的是(D) A.栈是非线性结构B.栈是一种树状结构C.栈具有先进先出的特征D.栈有后进先出的特征 6.链表不具有的特点是(B)A.不必事先估计存储空间 B.可随机访问任一元素 C.插入删除不需要移动元素 D.所需空间与线性表长度成正比 7.用链表表示线性表的优点是(便于插入和删除操作) 8.在单链表中,增加头结点的目的是(方便运算的实现) 9.循环链表的主要优点是(从表中任一结点出发都能访问到整个链表) 10.线性表L=(a1,a2,a3,……ai,……an),下列说法正确的是(D) A.每个元素都有一个直接前件和直接后件 B.线性表中至少要有一个元素 C.表中诸元素的排列顺序必须是由小到大或由大到小 D.除第一个和最后一个元素外,其余每个元素都有一个且只有一个直接前件和直接后件 11.线性表若采用链式存储结构时,要求内存中可用存储单元的地址(D) A.必须是连续的 B.部分地址必须是连续的C.一定是不连续的 D.连续不连续都可以 12.线性表的顺序存储结构和线性表的链式存储结构分别是(随机存取的存储结构、顺序存取的存储结构) 13.树是结点的集合,它的根结点数目是(有且只有1) 14.在深度为5的满二叉树中,叶子结点的个数为(31) 15.具有3个结点的二叉树有(5种形态) 16.设一棵二叉树中有3个叶子结点,有8个度为1的结点,则该二叉树中总的结点数为(13) 17.已知二叉树后序遍历序列是dabec,中序遍历序列是debac,它的前序遍历序列是(cedba) 18.已知一棵二叉树前序遍历和中序遍历分别为ABDEGCFH和DBGEACHF,则该二叉树的后序遍历为(DGEBHFCA) 19.若某二叉树的前序遍历访问顺序是abdgcefh,中序遍历访问顺序是dgbaechf,则其后序遍历的结点访问顺序是(gdbehfca) 20.数据库保护分为:安全性控制、 完整性控制 、并发性控制和数据的恢复。 1. 在计算机中,算法是指(解题方案的准确而完整的描述) 2.在下列选项中,哪个不是一个算法一般应该具有的基本特征(无穷性) 说明:算法的四个基本特征是:可行性、确定性、有穷性和拥有足够的情报。 3. 算法一般都可以用哪几种控制结构组合而成(顺序、选择、循环) 4.算法的时间复杂度是指(算法执行过程中所需要的基本运算次数) 5. 算法的空间复杂度是指(执行过程中所需要的存储空间) 6. 算法分析的目的是(分析算法的效率以求改进) ............ .................

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值