java顺序表和树的实现
一、顺序表
1.线性表
//java顺序表的实现,如ArrayList就是用线性表实现的,优点是查找快,缺点是添加或删除要移动很多元素,速度慢
public class SequenceList {
private int MAXLENGTH;//顺序表大小
private int count;//线性表存在数据个数
private Data[] data;
//数据储存
private static class Data{
String name;
int stuNo;
int scores;
}
public void init(int maxLength){
this.MAXLENGTH=maxLength;
data=new Data[MAXLENGTH];
}
//添加一条数据
public void add(Data d){
if(count==MAXLENGTH){
System.out.println("顺序表已满!不可添加");
}
else{
data[count]=d;
count++;
System.out.println("添加成功!");
}
}
//插入任意一条数据
public void insert(Data d,int position){
if(count==MAXLENGTH||position>MAXLENGTH||position<0){
System.out.println("顺序表已满或者插入位置有问题!不可插入");
}
else{
for(int i=count;i>=position;i--){
data[i+1]=data[i];
}
data[position]=d;
count++;
System.out.println("插入成功!");
}
}
//删除数据
public void del(int position){
if(position>count+1||position<0){
System.out.println("删除位置有误!");
}
else{
for(int i=position;i<count;i++){
data[i]=data[i+1];
}
count--;
System.out.println("删除成功!");
}
}
//更新一个数据
public void updata(Data d,int position){
if(position>count+1||position<0){
System.out.println("更新位置有误!");
}
else{
data[position]=d;
System.out.println("更新成功!");
}
}
//查询一个数据
public Data sel(int position){
if(position>count+1||position<0){
System.out.println("查询位置有误!");
return null;
}
else{
return data[position];
}
}
public static void main(String[] args){
SequenceList sl=new SequenceList();
sl.init(10);
Data d=new Data();
sl.add(d);
sl.insert(d, 0);
sl.del(0);
}
}
2.链式表
public class SingleList { private Node_Single head = null;//头节点
private Node_Single tail = null;//尾节点(空节点)相当于哨兵元素 /**
* 初始化一个链表(设置head )
* @param key
*/
public void initList(Node_Single node){
head = node;
head.next = tail;
} /**
* 添加一个元素
* @param node
*/
public void addTolist(Node_Single node){
if(head == null){
initList(node);
}else{
Node_Single tmp = head;
head = node;
node.next = tmp;
}
} /**
* 遍历链表,删除某一个节点
* @param node
* @param myList
*/
public void deleteNode(Node_Single node,SingleList myList){
if(myList == null){
return ;
}
Node_Single tmp =null;
for(tmp = myList.getHead();tmp!=null;tmp = tmp.next){
if(tmp.next !=null && node.getKey().equals(tmp.next.getKey())){//该元素和后一个元素相同。指针指向下一元素的下一元素
if(tmp.next.next != null){
tmp.next = tmp.next.next;
}else{
tmp.next = null;
}
}
}
} public void printList(SingleList myList){
Node_Single tmp =null;
for(tmp = myList.getHead();tmp!=null;tmp = tmp.next){
System.out.println(tmp.getKey());
}
} public Node_Single getHead() {
return head;
}
public void setHead(Node_Single head) {
this.head = head;
}
public Node_Single getTail() {
return tail;
}
public void setTail(Node_Single tail) {
this.tail = tail;
}
public static void main(String[] args){
SingleList myList = new SingleList();
Node_Single node_1 = new Node_Single("1");
Node_Single node_2 = new Node_Single("2");
Node_Single node_3 = new Node_Single("3");
Node_Single node_4 = new Node_Single("4");
Node_Single node_5 = new Node_Single("5");
Node_Single node_6 = new Node_Single("6");
Node_Single node_7 = new Node_Single("7");
myList.addTolist(node_1);
myList.addTolist(node_2);
myList.addTolist(node_3);
myList.addTolist(node_4);
myList.addTolist(node_5);
myList.addTolist(node_6);
myList.addTolist(node_7);
myList.deleteNode(node_3, myList);
myList.printList(myList);
}
public static class Node_Single {
public String key;//节点的值 public Node_Single next;//指向下一个的指针 public Node_Single(String key){//初始化head
this.key = key;
this.next = null;
}
public Node_Single(String key,Node_Single next){
this.key = key;
this.next = next;
}
public String getKey() {
return key;
} public void setKey(String key) {
this.key = key;
} public Node_Single getNext() {
return next;
} public void setNext(Node_Single next) {
this.next = next;
}
@Override
public String toString() {
return "Node_Single [key=" + key + ", next=" + next + "]";
}
}
}
三、二叉树
import java.util.Stack; public class BinaryTree { private TreeNode root=null; public BinaryTree(){
root=new TreeNode(1,"rootNode(A)");
} /**
* 创建一棵二叉树
* <pre>
* A
* B C
* D E F
* </pre>
* @param root
* @author WWX
*/
public void createBinTree(TreeNode root){
TreeNode newNodeB = new TreeNode(2,"B");
TreeNode newNodeC = new TreeNode(3,"C");
TreeNode newNodeD = new TreeNode(4,"D");
TreeNode newNodeE = new TreeNode(5,"E");
TreeNode newNodeF = new TreeNode(6,"F");
root.leftChild=newNodeB;
root.rightChild=newNodeC;
root.leftChild.leftChild=newNodeD;
root.leftChild.rightChild=newNodeE;
root.rightChild.rightChild=newNodeF;
} public boolean isEmpty(){
return root==null;
} //树的高度
public int height(){
return height(root);
} //节点个数
public int size(){
return size(root);
} private int height(TreeNode subTree){
if(subTree==null)
return 0;//递归结束:空树高度为0
else{
int i=height(subTree.leftChild);
int j=height(subTree.rightChild);
return (i<j)?(j+1):(i+1);
}
} private int size(TreeNode subTree){
if(subTree==null){
return 0;
}else{
return 1+size(subTree.leftChild)
+size(subTree.rightChild);
}
} //返回双亲结点
public TreeNode parent(TreeNode element){
return (root==null|| root==element)?null:parent(root, element);
} public TreeNode parent(TreeNode subTree,TreeNode element){
if(subTree==null)
return null;
if(subTree.leftChild==element||subTree.rightChild==element)
//返回父结点地址
return subTree;
TreeNode p;
//现在左子树中找,如果左子树中没有找到,才到右子树去找
if((p=parent(subTree.leftChild, element))!=null)
//递归在左子树中搜索
return p;
else
//递归在右子树中搜索
return parent(subTree.rightChild, element);
} public TreeNode getLeftChildNode(TreeNode element){
return (element!=null)?element.leftChild:null;
} public TreeNode getRightChildNode(TreeNode element){
return (element!=null)?element.rightChild:null;
} public TreeNode getRoot(){
return root;
} //在释放某个结点时,该结点的左右子树都已经释放,
//所以应该采用后续遍历,当访问某个结点时将该结点的存储空间释放
public void destroy(TreeNode subTree){
//删除根为subTree的子树
if(subTree!=null){
//删除左子树
destroy(subTree.leftChild);
//删除右子树
destroy(subTree.rightChild);
//删除根结点
subTree=null;
}
} public void traverse(TreeNode subTree){
System.out.println("key:"+subTree.key+"--name:"+subTree.data);;
traverse(subTree.leftChild);
traverse(subTree.rightChild);
} //前序遍历
public void preOrder(TreeNode subTree){
if(subTree!=null){
visted(subTree);
preOrder(subTree.leftChild);
preOrder(subTree.rightChild);
}
} //中序遍历
public void inOrder(TreeNode subTree){
if(subTree!=null){
inOrder(subTree.leftChild);
visted(subTree);
inOrder(subTree.rightChild);
}
} //后续遍历
public void postOrder(TreeNode subTree) {
if (subTree != null) {
postOrder(subTree.leftChild);
postOrder(subTree.rightChild);
visted(subTree);
}
} //前序遍历的非递归实现
public void nonRecPreOrder(TreeNode p){
Stack<TreeNode> stack=new Stack<TreeNode>();
TreeNode node=p;
while(node!=null||stack.size()>0){
while(node!=null){
visted(node);
stack.push(node);
node=node.leftChild;
}
while(stack.size()>0){
node=stack.pop();
node=node.rightChild;
}
}
} //中序遍历的非递归实现
public void nonRecInOrder(TreeNode p){
Stack<TreeNode> stack =new Stack<BinaryTree.TreeNode>();
TreeNode node =p;
while(node!=null||stack.size()>0){
//存在左子树
while(node!=null){
stack.push(node);
node=node.leftChild;
}
//栈非空
if(stack.size()>0){
node=stack.pop();
visted(node);
node=node.rightChild;
}
}
} //后序遍历的非递归实现
public void noRecPostOrder(TreeNode p){
Stack<TreeNode> stack=new Stack<BinaryTree.TreeNode>();
TreeNode node =p;
while(p!=null){
//左子树入栈
for(;p.leftChild!=null;p=p.leftChild){
stack.push(p);
}
//当前结点无右子树或右子树已经输出
while(p!=null&&(p.rightChild==null||p.rightChild==node)){
visted(p);
//纪录上一个已输出结点
node =p;
if(stack.empty())
return;
p=stack.pop();
}
//处理右子树
stack.push(p);
p=p.rightChild;
}
}
public void visted(TreeNode subTree){
subTree.isVisted=true;
System.out.println("key:"+subTree.key+"--name:"+subTree.data);;
} /**
* 二叉树的节点数据结构
* @author WWX
*/
private class TreeNode{
private int key=0;
private String data=null;
private boolean isVisted=false;
private TreeNode leftChild=null;
private TreeNode rightChild=null; public TreeNode(){} /**
* @param key 层序编码
* @param data 数据域
*/
public TreeNode(int key,String data){
this.key=key;
this.data=data;
this.leftChild=null;
this.rightChild=null;
} } //测试
public static void main(String[] args) {
BinaryTree bt = new BinaryTree();
bt.createBinTree(bt.root);
System.out.println("the size of the tree is " + bt.size());
System.out.println("the height of the tree is " + bt.height()); System.out.println("*******(前序遍历)[ABDECF]遍历*****************");
bt.preOrder(bt.root); System.out.println("*******(中序遍历)[DBEACF]遍历*****************");
bt.inOrder(bt.root); System.out.println("*******(后序遍历)[DEBFCA]遍历*****************");
bt.postOrder(bt.root); System.out.println("***非递归实现****(前序遍历)[ABDECF]遍历*****************");
bt.nonRecPreOrder(bt.root); System.out.println("***非递归实现****(中序遍历)[DBEACF]遍历*****************");
bt.nonRecInOrder(bt.root); System.out.println("***非递归实现****(后序遍历)[DEBFCA]遍历*****************");
bt.noRecPostOrder(bt.root);
}
}
java顺序表和树的实现的更多相关文章
- java 顺序表
想看看java版的数据结构,了解一下树的一些操作,写了个顺序表熟悉一下 package com.sqlist; /** * @author xiangfei * 定义一个顺序表 * */ public ...
- 数据结构Java实现02----线性表与顺序表
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- 线性表 及Java实现 顺序表、链表、栈、队列
数据结构与算法是程序设计的两大基础,大型的IT企业面试时也会出数据结构和算法的题目, 它可以说明你是否有良好的逻辑思维,如果你具备良好的逻辑思维,即使技术存在某些缺陷,面试公司也会认为你很有培养价值, ...
- 顺序表----java实现
最简单的数据结构--顺序表,此处以数组为例. 顺序表的优点:支持随机读取,内存空间利用率高. 顺序表的缺点:1.需要预先给出最大数据元素个数,这往往很难实现. 2.插入和删除时需要移动大量数据. Se ...
- Java实现顺序表
利用顺序存储结构表示的顺序表称为顺序表. 它用一组连续的地址存储单元一次存放线性表中的数据元素. 顺序表的实现是数据结构中最简单的一种. 由于代码中已经有详细注释,代码外不再阐述. 下次再陈上关于顺序 ...
- [Java算法分析与设计]--线性结构与顺序表(List)的实现应用
说到线性结构,我们应该立马能够在脑子里蹦出"Array数组"这个词.在Java当中,数组和对象区别基本数据类型存放在堆当中.它是一连串同类型数据存放的一个整体.通常我们定义的方式为 ...
- 数据结构——Java实现顺序表
一.分析 什么是顺序表?顺序表是指用一组地址连续的存储单元依次存储各个元素,使得在逻辑结构上相邻的数据元素存储在相邻的物理存储单元中的线性表.一个标准的顺序表需要实现以下基本操作: 1.初始化顺序表 ...
- 数据结构(java版)学习笔记(二)——线性表之顺序表
顺序表的优点: 随机存取元素方便,根据定位公式容易确定表中每个元素的存储位置,所以要指定第i个结点很方便 简单,直观 顺序表的缺点: 插入和删除结点困难 扩展不灵活,难以确定分配的空间 容易造成浪费 ...
- 使用JAVA数组实现顺序表
1,引入了JAVA泛型类,因此定义了一个Object[] 类型的数组,从而可以保存各种不同类型的对象. 2,默认构造方法创建了一个默认大小为16的Object数组:带参数的构造方法创建一个指定长度的O ...
随机推荐
- 每天一个linux命令(43):killall命令
Linux系统中的killall命令用于杀死指定名字的进程(kill processes by name).我们可以使用kill命令杀死指定进程PID的进程,如果要找到我们需要杀死的进程,我们还需要在 ...
- 快速入门系列--WCF--02消息、会话与服务寄宿
经过WCF基础的ABC学习,已经可以构建简单的WCF的服务,使用不同的服务地址和绑定类型,根据业务提供所需的服务契约.但不禁想问,服务所使用的消息报文是什么样的形式么?蕴含什么样内容呢?WCF服务是否 ...
- mysql关键字与自己设置的字段冲突
当我们设置字段大意的使用数据库关键字,会报与数据库有关错误,原因就是字段误与数据库关键字冲突造成. 解决办法:1.修改字段名字. 2.采用数组的方式进行调用.例如:thinkphp3.2手册中orde ...
- 你的 mixin 兼容 ECMAScript 5 吗
原文:Are your mixins ECMAScript 5 compatible? 作者:Nicholas C. Zakas 我最近在与客户合作的项目中,需要充分利用的 ECMAScript 5, ...
- 用户代理字符串userAgent可实现的四个识别
定义 用户代理字符串:navigator.userAgent HTTP规范明确规定,浏览器应该发送简短的用户代理字符串,指明浏览器的名称和版本号.但现实中却没有这么简单. 发展历史 [1]1993年美 ...
- Yii2的深入学习--自动加载机制
Yii2 的自动加载分两部分,一部分是 Composer 的自动加载机制,另一部分是 Yii2 框架自身的自动加载机制. Composer自动加载 对于库的自动加载信息,Composer 生成了一个 ...
- 利用Solr服务建立的站内搜索雏形---solr1
最近看完nutch后总感觉像好好捯饬下solr,上次看到老大给我展现了下站内搜索我便久久不能忘怀.总觉着之前搭建的nutch配上solr还是有点呆板,在nutch爬取的时候就建立索引到solr服务下, ...
- Bourbon – 简单轻量的 Sass 混入(Mixins)库
Bourbon 是一个简单易用的 Sass 混入(Mixin)库,无需配置.该混入包含用于支持所有现代浏览器的 CSS3 属性前缀.前缀需要确保在旧的浏览器支持优雅降级.Bourbon 使用 SCSS ...
- nodejs 回调地狱解决 promise async
nodejs毁掉地狱是一直被人诟病的,以下总结一下解决毁掉地狱的一些方法.(暂时研究的比较浅) 1.promise promise模式在任何时刻都处于以下三种状态之一:未完成(unfulfilled) ...
- PHP 中的Closure
PHP 中的Closure Closure,匿名函数,又称为Anonymous functions,是php5.3的时候引入的.匿名函数就是没有定义名字的函数.这点牢牢记住就能理解匿名函数的定义了. ...