算法练习---反转链表

1反转整个链表

1.1题目详情

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。

1.2递归

  class Solution {
    public ListNode reverseList(ListNode head) {
       
       //递归终止条件
       if(head==null||head.next==null) return head;

       //进入递归,最后返回最后一个节点,即为反转后的头节点
       ListNode newHead=reverseList(head.next);

       //当前节点的下一个节点的下一个节点指向当前节点
       head.next.next=head;
       head.next=null;

       return newHead;

       
    }
}

1.3迭代

class Solution {
    public ListNode reverseList(ListNode head) {
       
       if(head==null||head.next==null) return head;

       ListNode prev=null;
       ListNode next=null;
       ListNode curr=head;

       while(curr!=null){
           next=curr.next;
           curr.next=prev;
           prev=curr;
           curr=next;

       }

       return prev;
    }
}
1.4递归和迭代总结
1.4.1递归,就是在运行的过程中调用自己。
 构成递归需具备的条件:
     1. 子问题须与原始问题为同样的事,且更为简单;
     2. 不能无限制地调用本身,须有个出口,化简为非递归状况处理。
1.4.2 迭代法也称辗转法,是一种不断用变量的旧值递推新值的过程,跟迭代法相对应的是直接法(或者称为一次解法),即一次性解决问题。
1.4.3递归中一定有迭代,但是迭代中不一定有递归,大部分可以相互转换.能用迭代的不用递归,

2反转链表指定区间的节点

2.1题目详情

给你单链表的头指针 head 和两个整数 left 和 right ,其中 left <= right 。请你反转从位置 left 到位置 right 的链表节点,返回 反转后的链表 。

2.2递归

class Solution {
	//保存第n+1个节点,因为反转之后原头节点的下一个节点变为第n+1个节点
    ListNode node=null;
    //反转前n个节点
    public ListNode reverseN(ListNode head,int n){
        if(n==1){
            node=head.next;
            return head;
        }

        ListNode last=reverseN(head.next,n-1);

        head.next.next=head;
        head.next=node;

        return last;

    }
    public ListNode reverseBetween(ListNode head, int left, int right) {
        if(left==1){
        	//相当于反转前right个节点
            return reverseN(head,right);
        }else{
            head.next=reverseBetween(head.next,left-1,right-1);
            return head;
        }
    }
}

2.3迭代

class Solution {
    public ListNode reverseBetween(ListNode head, int left, int right) {
        ListNode pre=null;
        ListNode beginNode=null;
        ListNode endNode=null;
        ListNode temp=head;
        int count=1;
        while(temp!=null){
            if(left-1==count){
                beginNode=temp;
            }
            if(right+1==count){
                endNode=temp;
                break;
            }
            temp=temp.next;
            count++;
        }
       
        ListNode prev=endNode;
        ListNode next=null;
        //beginNode==null说明left=1,即开始反转的节点为头节点
        ListNode curr=beginNode==null?head:beginNode.next;

        while(curr!=endNode){
            next=curr.next;
            curr.next=prev;
            prev=curr;
            curr=next;

        }

        if(beginNode==null) return prev;

        beginNode.next=prev;

        return head;

    }
}

3k个一组反转链表

3.1题目详情给你链表的头节点 head ,每 k 个节点一组进行翻转,请你返回修改后的链表。

k 是一个正整数,它的值小于或等于链表的长度。如果节点总数不是 k 的整数倍,那么请将最后剩余的节点保持原有顺序。

你不能只是单纯的改变节点内部的值,而是需要实际进行节点交换。

3.2递归加迭代

class Solution {
	//反转[start,end)
    public ListNode reverse(ListNode start,ListNode end){
        ListNode prev=end;
        ListNode next=null;
        ListNode curr=start;

        while(curr!=end){
            next=curr.next;
            curr.next=prev;
            prev=curr;
            curr=next;
        }

        return prev;
    }
    public ListNode reverseKGroup(ListNode head, int k) {

        ListNode startNode=head;
        ListNode endNode=head;
        for(int i=0;i<k;i++){
           //节点总数小于k,不进行反转,直接返回start节点
           if(endNode==null) return startNode;
           endNode=endNode.next;
        }
		//反转后的节点成为新的头节点
        ListNode newHead=reverse(startNode,endNode);
        //原头节点的下一个节点为下一次反转后的头节点
        startNode.next=reverseKGroup(endNode,k);
        return newHead; 
    }
}
  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 西安海思机试是针对Java编程语言的一道考试目。海思机试通常要求考生能够熟练掌握Java语言的基本语法和常用类库,并能够运用这些知识解决简单的编程问。 在机试中,通常会涉及到一些基本的编程概念,如变量、循环、条件判断、函数等。考生需要使用Java语言来实现特定的功能或逻辑,并输出正确的结果。 对于西安海思机试,可能会包含以下一些例子: 1. 写一个程序,输出从1到100的所有偶数。 解思路:使用循环从1到100遍历,判断每个数字是否为偶数,如果是则输出。 2. 写一个程序,求一个数组中的最大值和最小值。 解思路:使用循环遍历数组中的每个元素,通过比较更新最大值和最小值。 3. 写一个程序,判断一个字符串是否是回文字符串。 解思路:使用循环将字符串反转,并与原字符串进行比较,如果相同则是回文字符串。 对于这些机试,考生应该具备良好的编程思维和逻辑分析能力,善于利用Java语言特性和类库来解决问。此外,高效的编码能力和代码风格的优化也是考生需要具备的能力。 要准备西安海思机试,考生可以通过复习Java基本语法、数据类型、循环、条件判断和函数等知识,并通过编写代码实践来提升自己的编程技巧。还可以参考一些教材、教程或者在线编程平台上的库进行练习和加深理解。 最后,机试不仅仅是一次考试,更重要的是通过实践来提升自己的编程能力和解决问的能力。希望以上回答对你有所帮助。 ### 回答2: 西安海思机试是一道关于Java的目。Java是一种常见的高级编程语言,具有跨平台的特性,可以用于开发各种类型的软件应用程序。机试通常用来测试考生在编程领域的技能和知识。 对于这样的机试,可能会包括一系列的编程目,考察考生的语法知识、算法和逻辑思维能力等方面。在解答机试时,需要考生清晰理解目的要求,并用合适的Java代码进行解答。 解答机试的关键在于理解目要求,并用合适的算法和Java编程语言来实现解决方案。在解答过程中,还需要注意代码的规范性、可读性和效率。 对于想要参加西安海思机试的考生,建议他们提前准备,复习并熟悉Java编程语言的基础知识和常见的算法。此外,也可以通过练习机试,提高自己的解决问和编程能力。 总之,西安海思机试-java是一种考察考生Java编程能力和知识技能的方式。参加机试需要考生具备扎实的编程基础和算法思维,同时也需要平时勤加练习和积累,提高自己在编程领域的能力。 ### 回答3: 西安海思机试是一个关于Java编程的考试目。在这个机试中,考生需要完成一些与Java语言相关的编程任务,以展示自己的编程能力。根据目的要求,考生可能需要使用Java编程语言来实现一些功能,如算法设计、数据结构操作等。 在西安海思机试中,考生需要具备扎实的Java编程基础以及良好的逻辑思维能力。他们需要理解目要求,分析问,并设计出合适的解决方案。在编程过程中,考生需要熟练运用Java的各种语法、类库和工具,以便高效地完成任务。此外,考生还需要注意代码的可读性和可维护性,以便其他程序员理解并维护他们的代码。 西安海思机试涉及的内容可能包括但不限于以下几个方面: 1. Java基础知识:如基本语法、面向对象编程概念、异常处理、输入输出等。 2. 数据结构算法:如链表、栈、队列、排序算法等。 3. 多线程编程:如线程创建与启动、同步与互斥、线程池等。 4. 网络编程:如TCP/IP通信、Socket编程等。 5. 数据库操作:如JDBC编程、SQL语句执行等。 在准备西安海思机试时,考生可以通过以下途径提升自己的编程能力: 1. 学习和掌握Java编程语言的基础知识,包括语法、集合框架、IO操作等。 2. 多进行编程练习,不断提高自己的编码能力。 3. 阅读与Java相关的书籍、文章以及开源项目,学习他人的经验和优秀的编码风格。 4. 加入编程社区或者论坛,与其他程序员交流经验。 5. 参加在线教育平台或培训机构的Java课程,接受系统的培训。 总之,参加西安海思机试是提升自己Java编程能力的一个很好的机会。通过扎实的基础知识和充分的准备,考生可以在这个机试中展现出自己的编程实力。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

路上阡陌

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值