每日算法(1)之单链表

1.测试链表中有效节点的个数

这道算法题的思路很简单:设置一个变量记录有效节点的个数,通过在while循环来实现

java 复制代码
public static int getLength(HeroNode head){
        if(head.next==null){//空链表
            return 0;
        }
        int length=0;
        //定义一个辅助的变量,这里我们没有统计头节点
        HeroNode cur=head.next;
        while(cur!=null){
                length++;
                cur=cur.next;//遍历链表
        }
        return length;
    }

2.查找单链表中的倒数第k个节点[新浪面试题]

复制代码
思路
1.编写一个方法,接受头结点head,同时接收一个index
2.index表示是倒数第index个节点
3.先把链表从头到尾遍历一遍,得到链表的总长度getLength(不含头结点)
4.得到size后,我们从链表的第一个开始遍历(size-index)个,就可以得到
5.如果找到就返回该节点,否则返回null

这里的思路其实就是将倒数转换成正数,寻找其中的规律

假设:我们现在有五个数分别为:1,2,3,4,5 我们要找倒数第一位数5,对应正数第五位:而我们 从1到5遍历次数为4;

倒数第二位数4,对应正数第四位:从1到4遍历次数为3;

倒数第三位数3,对应正数第三位: 从1到3遍历次数为2;

即数学表达式为:遍历次数=size-index

java 复制代码
public static HeroNode findLastIndexNode(HeroNode head,int index){
        //如果链表为空,返回null
        if(head.next==null){
            return null;//没有找到
        }
        //第一次遍历得到链表的总长度(有效节点个数)
        int size=getLength(head);
        //第二次遍历 size-index位置,就是我们倒数第k个节点
        //先对index进行一个判断
        if(index<=0||index>size){
            return null;
        }
        //定义辅助变量,for循环到倒数的index
        HeroNode cur=head.next;
        for(int i=0;i<size-index;i++){
            cur=cur.next;
        }
        return cur;
    }

3.单链表的反转[腾讯面试题]

思路图解

思路: 1.我们需要创建一个新的头节点

2.从头到尾遍历原来的链表,每遍历一个边取出一个,将其放在新的链表reverseHead的最前端

3.将所有节点添加到reverseHead这个头节点后,再head.next=reverseHead.next,将rev后面跟着的节点都放在head这个原来的头节点上,便完成反转

java 复制代码
public static void reverseList(HeroNode head){
        //如果当前的链表为空,或者只有一个节点,无需反转,直接返回
        if(head.next==null||head.next.next==null){
            return ;
        }
        HeroNode reverseHead=new HeroNode(0,"","");
        HeroNode cur=head.next;
        HeroNode next=null;//指向当前节点[cur]的下一个节点
        //遍历原来的链表,每遍历一个节点,就将其取出,并放在新的链表reverseHead的最前端
        while(cur!=null){
         next=cur.next;//先暂时保存当前节点的下一个节点,因为后面这个节点就在新的链表里面,下一个节点就成为我们移动的对象
         cur.next=reverseHead.next;//将cur的下一个节点指向新的链表的最前端
         reverseHead.next=cur;//cur后移
         cur=next;
        }
        //将head.next指向reverseHead.next,实现单链表的反转
        head.next=reverseHead.next;
    }

4.从头到尾打印单链表[百度面试题]

因为反转遍历的方法会破坏单链表的原始结构,所以这里选择用栈的特性先进后出完成这道题

java 复制代码
public static void reversePrint(HeroNode head){
        if(head.next==null){
            return;//空链表不能打印
        }
        //创建一个栈,将各个节点压入栈
        Stack<HeroNode> stack=new Stack<>();
        HeroNode cur=head.next;
        while(cur!=null){
            stack.push(cur);
            cur=cur.next;
        }
        //将栈中的节点进行打印,pop出栈
        while(stack.size()>0){
            System.out.println(stack.pop());//stack的特点先进后出
        }
    }
相关推荐
一个不知名程序员www18 分钟前
算法学习入门---二分查找(C++)
c++·算法
2301_8079973843 分钟前
代码随想录-day26
数据结构·c++·算法·leetcode
闭着眼睛学算法1 小时前
【双机位A卷】华为OD笔试之【排序】双机位A-银行插队【Py/Java/C++/C/JS/Go六种语言】【欧弟算法】全网注释最详细分类最全的华子OD真题题解
java·c语言·javascript·c++·python·算法·华为od
TL滕1 小时前
从0开始学算法——第一天(认识算法)
数据结构·笔记·学习·算法
小欣加油1 小时前
leetcode 3318 计算子数组的x-sum I
c++·算法·leetcode·职场和发展
love is sour1 小时前
聚类(Clustering)详解:让机器自己发现数据结构
算法·支持向量机·聚类
烟袅1 小时前
LeetCode 142:环形链表 II —— 快慢指针定位环的起点(JavaScript)
前端·javascript·算法
CoovallyAIHub1 小时前
OCR战场再起风云:LightOnOCR-1B凭什么比DeepSeekOCR快1.7倍?(附演示开源地址)
深度学习·算法·计算机视觉
海琴烟Sunshine2 小时前
leetcode 190. 颠倒二进制位 python
python·算法·leetcode
Xの哲學2 小时前
Linux eMMC子系统深度解析:从硬件协议到内核实现
linux·网络·算法·架构·边缘计算