JAVA数据结构与算法(一)

1.1 数据结构和算法内容介绍英

1.1.1先看几个经典的算法面试题字符串匹配问题:

 1)有一个字符串 str1=""硅硅谷尚硅谷你尚硅尚硅谷你尚硅谷你尚硅你好"",和一个子串str2="尚硅谷你尚硅你"

2) 现在要判断 strl 是否含有 str2,如果存在,就返回第一次出现的位置,如果没有, 则返回-1

3)要求用最快的速度来完成匹配

4)你的思路是什么?

暴力匹配[简单,但是效率低]

KMP 算法《部分匹配表》

汉诺塔游戏

请完成汉诺塔游戏的代码:要求:

1)将A塔的所有圆盘移动到C塔

2)小圆盘上不能放大圆盘

 3)在三根柱子之间一次只能移动一个圆盘

1.2线性结构和非线性结构数据结构包括:

1.2.1线性结构和非线性结构。 线性结构

1)线性结构作为最常用的数据结构,其特点是数据元素之间存在一对一的线性关系

2)线性结构有两种不同的存储结构,即顺序存储结构和链式存储结构。 顺序存储的线性表称为顺序表,顺序表中的存储元素是连续的

3)链式存储的线性表称为链表,链表中的存储元素不一定是连续的,元素节点中存放数据元素以及相邻元素的地址信息

4)线性结构常见的有:数组、队列、链表和栈.

1.2.2非线性结构非线性结构包括:

二维数组,多维数组,广义表,树结构,图结构

链表特点:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值