IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 链表练习题(一) -> 正文阅读

[数据结构与算法]链表练习题(一)

1.删除链表中等于给定值val的所有节点。

解题思路:遍历链表,查找到给定值节点,删除改节点,即使改节点的上一个节点指向下下一个节点。

class ListNode{
    int val=0;
    ListNode next=null;
    public ListNode(){

    }
    public ListNode(int val){
        this.val=val;
        this.next=null;

    }
    public ListNode(int val,ListNode next){
        this.val=val;
        this.next=next;
    }

}
 //删除链表中的指定元素
    public static ListNode removeElements(ListNode head,int val){
        if(head==null){
            return  null;
        }

        ListNode prev=head;
        ListNode cur=head.next;

        for (;cur!=null;){
            if (cur.val==val){
                prev.next=cur.next;
                cur=prev.next;
            }else {
                prev=prev.next;
                cur=cur.next;
            }
        }
        if(head.val==val){
            head=head.next;
        }
        return head;
    }

2.反转一个单链表。

解题思路:

创建prevNode=null newHead=null currentNode=head

在循环中,currentNode.next=null,的时候找到反转链表的新节点 newHead也就是原链表的最后一个节点。

之后使得 第一个节点currentNode指向null(prevNode)

prevNode=currentNode 当前节点(第一个节点)

currentNode=nextNode 下一个节点

如此循环 ,即可实现链表的反转。

public static ListNode  reverseList(ListNode head){
        if(head==null){
            return  null;
        }
        if (head.next==null){
            return  head;
        }
        ListNode prevNode=null;
        ListNode newHead=null;
        ListNode currentNode=head;
        while (currentNode!=null){
            ListNode nextNode=currentNode.next;
            if (nextNode==null){
                newHead=currentNode;
            }
            currentNode.next=prevNode;
            prevNode=currentNode;
            currentNode=nextNode;
        }
        return newHead;
    }

3.给定一个带有头结点 head 的非空单链表,返回链表的中间结点。如果有两个中间结点,则返回第二个中间结点。

解题思路:获取链表长度 ,获取链表长度的一半再遍历即可。

public  int getLength(ListNode head){
        int length=0;
        //遍历链表
        for (ListNode cur=head;cur!=null;cur=cur.next){
            length++;
        }
        return length;
    }
    public ListNode middleNode(ListNode head){
        if (head==null){
            return  null;
        }
        int len=getLength(head)/2;
        ListNode cur=head;
        for (int i=0;i<len;i++){
            cur=cur.next;
        }
        return cur;
    }

4.输入一个链表,输出该链表中倒数第k个结点。

解题思路:

首先判断一下成立条件

获取链表的长度len len-k就是该节点的位置

链表从头开始走,走len-k步就是该节点

 public ListNode FindKthToTail(ListNode head,int k){
   if (head==null){
       return null;
   }
   if (k<=0){
       return null;
   }
   int len=getLength(head);
   if (k>len){
       return null;
   }
   int steps=len-k;
   ListNode cur=head;
   for (int i=0;i<steps;i++){
       cur=cur.next;
   }
   return cur;
   }
5. 将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。
解题思路:
定义一个新链表,创建傀儡节点便于后续插入
在两个链表不为空的条件下,对比两个链表 节点值的大小
如果cur1的值比cur2的值小,那么cur1链表的值就首先插入到新链表当中,反之则插入cur2(这里注意不要忘记更新链表节点)
如果cur1链表插入完成,就将剩余的cur2链表的剩余节点都插入到新链表,反之则将cur1的剩余节点全部插入到新链表。
 public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
      if (l1==null){
          return l2;
      }
      if (l2==null){
          return l1;
      }
      ListNode cur1=l1;
      ListNode cur2=l2;
      ListNode newHead=new ListNode(0);
      ListNode newTail=newHead;
      while (cur1!=null && cur2!=null){
          if (cur1.val<cur2.val){
              newTail.next=cur1;
              cur1=cur1.next;
          }else {
              newTail.next=cur2;
              cur2=cur2.next;
          }
          if (cur1==null){
              newTail.next=cur2;
          }else{
              newTail.next=cur1;
          }
      }
      return newHead.next;
    }
6. 编写代码,以给定值 x 为基准将链表分割成两部分,所有小于 x 的结点排在大于或等于 x 的结点之前。
解题思路:
定义两个新链表,使用傀儡节点简化插入操作
将所有小于X 的值插入smallTail,反之插入largeTail,
最终再将两个链表合并,使得smallTail.next=largeTail即可。
 public ListNode partition(ListNode pHead, int x) {
       if (pHead==null){
           return null;
       }
       if (pHead.next==null){
           return pHead;
       }
       ListNode smallHead=new ListNode(0);
       ListNode smallTail=smallHead;
       ListNode  largeHead=new ListNode(0);
       ListNode largeTail=largeHead;

       for (ListNode cur=pHead;cur!=null;cur=cur.next){
           if (cur.val<x){
               smallTail.next=new ListNode(cur.val);
               smallTail=smallHead.next;
           }else {
               largeTail.next=new ListNode(cur.val);
               largeTail= smallTail.next;
           }
       }
        smallTail.next=largeTail;
       return smallHead.next;
    }

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-07-31 16:53:22  更:2021-07-31 16:54:29 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/7 15:47:36-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码