java实现顺序表、链表、栈 (x)->{持续更新}

1.java实现节点

/**
 * 节点
 * @luminous-xin
 * @param <T>
 */
public class Node<T> {
    T data;
    Node<T> next;
    public Node(Node<T> n){
        next = n;
    }
    public Node(T obj,Node<T> n){
        data = obj;
        next = n;
    }
    public T getData(){
        return data;
    }
    public Node<T> getNext(){
        return next;
    }
}

2.java实现链表

/**
 * 链表
 * @author luminous-xin
 * @param <T>
 */
public class ListLink<T> {
    //头指针
    private Node<T> head;
    //单链表的长度
    private int length;

    //构造一个空的链表
    public ListLink() {
        length = 0;
        head = new Node<T>(null);
    }

    //获取链表头节点的位置
    public Node<T> getHead() {
        return head;
    }

    //在链表中插入一个元素
    public boolean add(T obj, int pos) {
        if (pos < 1 || pos > length + 1) {
            System.out.println("pos值不合法");
            return false;
        }
        int num = 1;
        Node<T> p = head, q = head.next;
        while (num < pos) {
            p = q;
            q = q.next;
            num++;
        }
        p.next = new Node<T>(obj, q);
        length++;
        return true;

    }

    //删除链表中某各元素
    public T remove(int pos) {
        if (isEnpty()) {
            System.out.println("链表为空表");
            return null;
        }
        if (pos < 1 || pos > length + 1) {
            System.out.println("pos值不合法");
            return null;
        }
        int num = 1;
        Node<T> p = head, q = head.next;
        while (num < pos) {
            p = q;
            q = q.next;
            num++;
        }
        p.next = q.next;
        length--;
        return q.data;
    }

    //获取链表中一个元素的值
    public T value(int pos) {
        if (isEnpty()) {
            System.out.println("链表为空表");
            return null;
        }
        if (pos < 1 || pos > length + 1) {
            System.out.println("pos值不合法");
            return null;
        }
        int num = 1;
        Node<T> p = head, q = head.next;
        while (num < pos) {
            p = q;
            q = q.next;
            num++;
        }
        return q.data;
    }

    //在链表中查找一个元素,返回该元素下标的索引
    public int find(T obj) {
        if (isEnpty()) {
            System.out.println("链表为空表");
            return -1;
        }
        int num = 1;

        Node<T> p = head, q = head.next;
        while (q!= null) {
            if (obj.equals(q.data)) {
                return num;
            }
            p = q;
            q = q.next;
            num++;
        }
        return -1;
       /* Node<T> p = head.next;
        while (p != null) {
            if (p.data.equals(obj) == false) {
                p = p.next;
                num++;
            } else break;

        }
        if (p == null) {
            return -1;
        }
        return num;*/
    }

    //更新链表中某各元素
    public boolean modify(T obj, int pos) {
        if (isEnpty()) {
            System.out.println("链表为空表");
            return false;
        }
        if (pos < 1 || pos > length + 1) {
            System.out.println("pos值不合法");
            return false;
        }
        int num = 1;
        Node<T> q = head.next;
        while (num < pos) {
            q = q.next;
            num++;
        }
        q.data = obj;
        return true;
    }

    //判空
    public boolean isEnpty() {
        return length == 0;
    }

    //求链表中数据元素的个数
    public int size() {
        return length;
    }

    //一次访问链表中每个元素并输出
    public void nextOrder() {
        Node<T> q = head.next;
        while (q != null) {
            System.out.println(q.data);
            q = q.next;
        }
    }

    //销毁一个已经存在的链表
    public void clear() {
        length = 0;
        head.next = null;
    }

    public static void main(String[] args) {
        ListLink<Integer> l = new ListLink<>();
        int i;
        int a[] = {23, 56, 12, 49, 35};
        for (i = 0; i < a.length; i++) {
            l.add(a[i], i + 1);
        }
        System.out.println("单链表中的数据元素为:");
        l.nextOrder();
        System.out.println(l.find(5));

    }

3.java实现顺序表

/**
 * 顺序表
 * @author luminous-xin
 * @param <T>
 */
public class SequenceList<T> {
    final int maxSize = 10;           //顺序表中一维数组的长度
    private T[] listArray;             //存储元素的数组对象
    private int length;                 //保存顺序表的当前长度
    public SequenceList(){                   //构造一个空的线性表
        length = 0;
        listArray = (T[])new Object[maxSize];
    }
    public SequenceList(int n){
        if(n <= 0){
            System.out.println("error");
            System.exit(1);
        }
        length = 0;
        listArray = (T[])new Object[n];
    }
    public boolean add(T obj , int pos){                  //在线性表中插入一个新元素
        if(pos < 1 || pos > length + 1){                //检验插入位置的有效性
            System.out.println("pos不合法");
            return false;
        }
        if(length == listArray.length){                 //扩容
            T[] p = (T[])new Object[length*2];
            for (int i = 0; i < length; i++) {
                listArray = p;
            }
        }
        for (int i = length; i > pos; i--) {           //插入
            listArray[i] = listArray[i-1];
        }
        listArray[pos-1] = obj;
        length++;
        return true;
    }
    public T remove(int pos){                               //在线性表中删除一个元素
        if(isEmpty()){
            System.out.println("顺序表为空,无法执行删除操作");
            return null;
        }else{
            if(pos<1 || pos >length){
                System.out.println("pos不合法");
                return null;
            }

            T  x = listArray[pos-1];                          //备份被删除的元素,将其作为返回值返回
            for (int i = pos ; i <= length; i++) {
                listArray[i-1] = listArray[i];
            }
            length++;
            return x;
        }
    }

    public int find(T obj){                      //在线性表中查找一个元素
        if(isEmpty()){
            System.out.println("顺序表为空");
            return -1;
        }else{
            for(int i = 0 ; i <length ; i++){
                if(listArray[i].equals(obj)){
                    return i + 1;                     //返回该元素的位置
                }
            }
            return -1;
        }
    }
    public T value(int pos){                                  //获取线性表中的一个元素
        if(isEmpty()){
            System.out.println("顺序表为空");
        }else{
            if(pos < 1 || pos > length +1){
                System.out.println("pos值不合法");
            }
        }
        return listArray[pos - 1];
    }
    public boolean modify(T obj,int pos){                      //更新线性表中的某各元素
        if(isEmpty()){
            System.out.println("顺序表为空");
            return false;
        }else{
            if(pos < 1 || pos > length  ){
                System.out.println("pos值不合法");
                return false;
            }
        }
        listArray[pos-1] = obj;
        return true;
    }
    public boolean isEmpty(){                              //判空
        return length == 0;
    }
    public int size(){                              //求线性表中数据元素的个数
        return length;
    }
    public void nextOrder(){                      //一次访问栈中的每个元素并输出
        for(int i = 0 ; i< length; i++ ){
            System.out.println(listArray[i]);
        }
    }
    public void clear(){                       //销毁一个已经存在的线性表
        length = 0;
    }


}

4.链表的应用,合并两个有序链表

public class Chap2_2 {
    public static <T extends Comparable> void MergeList_L(ListLink<T> la, ListLink<T> lb ,ListLink<T> lc){
        Node<T> pa,pb,pc;
        pa = la.getHead().next;
        pb = lb.getHead().next;
        pc = lc.getHead();

        while(pa != null && pb != null){
            if(pa.data.compareTo(pb.data)<0){
                pc.next = pa;
                pc = pa ;
                pa = pa.next;
            }else{
                pc.next = pb;
                pc = pb;
                pb = pb.next;
            }

            while (pa != null){
                pc.next = pa;
                pc =  pc.next;
                pa = pa.next;
            }
            while (pb != null){
                pc.next = pb;
                pc = pb;
                pb = pb.next;
            }
            la.clear();
            lb.clear();
        }
    }
    public static void main(String[] args) {
        int i,j,k = 0;
        int[] b = {12,23,35,49,56};
        int[] a = {10,15,20};
        ListLink<Integer> la = new ListLink<>();
        ListLink<Integer> lb = new ListLink<>();
        ListLink<Integer> lc = new ListLink<>();
        for ( i = 0; i < a.length; i++) {
            la.add(a[i],i+1);
        }
        System.out.println("单链表a中的元素为:");
        la.nextOrder();
        for (j = 0; j < b.length; j++) {
            lb.add(b[j],j+1);
        }
        System.out.println("单链表b中的数据元素为:");
        lb.nextOrder();
        MergeList_L(la,lb,lc);
        System.out.println("单链表c中的元素为:");
        lc.nextOrder();
    }
}

 

 

5.java实现顺序栈

/**
 * 顺序栈
 * @author luminous-xin
 * @param <T>
 */
public class SequenceStack<T> {
    final int maxSize = 10;
    private T[] stackArray;
    private int top;
    //各方法的具体实现后有详细描述
    public SequenceStack(){
        top = -1;
        stackArray = (T[])new Object[maxSize];
    }
    public SequenceStack(int n){
        if(n<=0){
            System.out.println("数组长度要大于零,否则退出程序运行!");
            System.exit(1);
        }
        top = -1;
        stackArray = (T[])new Object[n];
    }
    //在栈顶位置插入一个新元素
    public void push(T obj){
        if(top == stackArray.length-1){
            T[] p = (T[])new Object[top*2+2];
            for (int i = 0; i <= top; i++){
                p[i] = stackArray[i];
            }
            stackArray = p;
        }

        top++;
        stackArray[top] = obj;
    }
    //删除栈顶元素
    public T pop(){
        if(top == -1) {
            System.out.println("数据栈已空,无法删除元素");
            return null;
        }
        top--;
        return stackArray[top+1];
    }
    //取栈顶数据元素
    public T getHead(){
        if (top == -1){
            System.out.println("数据栈已空,无法删除元素");
            return null;
        }
        return stackArray[top];
    }
    //判断当前栈是否为空
    public boolean isEmpty(){
        return top == -1;
    }
    //求出栈中元素的个数
    public int size(){
        return top +1;
    }
    //依次访问栈中元素并输出
    public void nextOrder(){
        for(int i = top ; i >= 0;i--){
            System.out.println(stackArray[i]);
        }
    }
    //销毁一个已经存在的栈
    public void clear(){
        top = -1;
    }
}

 6.java实现链栈

/**
 * 链栈
 * @luminous-xin
 * @param <T>
 */
public class LinkStack<T> {
    private Node<T> top;   //栈顶指针
    private int length;     //存储栈的长度
    public LinkStack(){     //构造一个空的栈
        length = 0;
        top = null;
    }
    public void push(T obj){        //入栈
        top = new Node<T>(obj,top);
        length++;
    }
    public T pop(){                 //出栈
        if(top == null){
            System.out.println("栈已空,无法删除");
            return null;
        }
        T x = top.data;
        top = top.next;
        length--;
        return x;
    }
    public T getHead(){             //取栈顶元素
        if(top == null){
            System.out.println("栈已空,无法删除");
            return null;
        }
        return top.data;
    }
    public int size(){              //求出栈中元素的个数
        return length;
    }
    public boolean isEmpty(){       //判断栈是否为空
        if (top ==null){
            return true;
        }
        return false;
    }
    public void nextOrder(){        //便利栈
        Node<T> p = top;
        while (p != null){
            System.out.println(p.data);
            p = p.next;
        }
    }

    public void clear(){            //销毁一个栈
        top = null;
    }
}

 7.java实现顺序链表

import org.omg.CORBA.Object;

/**
 * 循环队列
 * @author luminous
 * @param <T>
 */
public class SequenceQueue<T> {
    final int maxSize = 10;
    private T queueArray[];
    private int front, rear;

    public SequenceQueue() {
        rear = front = 0;
        queueArray = (T[]) new Object[maxSize];
    }

    public void enQueue(T obj) {                            //入队
        if ((rear + 1) % queueArray.length == front) {
            T[] p = (T[]) new Object[queueArray.length * 2];
            if (rear == ((T[]) queueArray).length) {
                for (int i = 0; i <= rear; i++) {
                    p[i] = queueArray[i];
                }
            } else {
                int i,j = 1;
                for (i = front + 1; i<queueArray.length;i++,j++)
                    p[j] = queueArray[i];
                for (i = 0;i<= rear ; i++,j++)
                    p[j] = queueArray[i];
                front = 0;
                rear = queueArray.length-1;
            }
            queueArray = p;
        }
        rear = (rear+1)%queueArray.length;
        queueArray[rear] = obj;
    }
    public T DeQueue(){                             //出队
        if(isEmpty()){
            System.out.println("队列已空,无法出队!");
            return null;
        }
        front = (front +1)%queueArray.length;
        return queueArray[front];

    }
    public T getTop(){                                  //取出头元素
        if(isEmpty()){
            System.out.println("队列已空,无法读取元素!");
            return null;
        }
        return queueArray[(front+1)%queueArray.length] ;
    }
    public boolean isEmpty(){                   //队列的非空队列
        return front==rear;
    }
    public int size(){                      //求队列长度
        return (rear - front +queueArray.length)%queueArray.length;
    }
    public void nextOrder(){            //遍历队列
        int i,j = front ;
        for (i = 1; i < size(); i++) {
            j = (j+1)%queueArray.length;
            System.out.println(queueArray[j]);

        }
    }
    public void clear(){       //清空队列
            front = rear =0;
    }
}
posted @ 2019-09-23 21:32  小怪兽他爹爹  阅读(497)  评论(0编辑  收藏  举报