请用java实现以下功能,每一行代码都需要详细注解。给你单链表的头节点 head ,请你反转链表,并返回反转后的链表
时间: 2023-03-14 22:05:37 浏览: 105
反转单链表的java代码如下:// 定义一个节点类,用于存储每一个节点的信息
class Node {
int val;
Node next;
Node(int x) { val = x; }
}// 定义函数,用于反转链表
public Node reverse(Node head) {
Node pre = null;
Node cur = head;
while (cur != null) {
Node temp = cur.next;
cur.next = pre;
pre = cur;
cur = temp;
}
return pre;
}// 详细注释
/*
* 反转单链表:
* 1、定义一个节点类,用于存储每一个节点的信息
* 2、定义函数,用于反转链表,定义pre指针和cur指针,当cur指针不为空时,循环执行以下操作:
* - 使用temp变量来存储cur.next的值
* - 使用cur.next指向pre指针
* - 更新pre指针指向cur指针
* - 更新cur指针指向temp
* 3、最后返回pre指针指向的节点,即为反转后的链表
*/
相关问题
请用java 栈实现以下功能,每一行代码都需要详细注解。给你单链表的头节点 head ,请你反转链表,并返回反转后的链表
// 初始化一个新的链表
ListNode newHead = null; // 用一个指针遍历原链表
ListNode pNode = head; // 遍历原链表,每遍历一个节点,将其放到新链表的最前端
while(pNode!=null){
ListNode temp = pNode; // 临时存储当前节点
pNode = pNode.next; // 指针向后移动
temp.next = newHead; // 将当前节点放到新链表的最前端
newHead = temp;
} // 返回反转后的链表
return newHead;
请用java中栈实现以下功能,每一行代码都需要详细注解。给你单链表的头节点 head ,请你反转链表,并返回反转后的链表
/**
* 反转链表
*
* @param {Node} head 链表的头节点
* @return {Node} 反转后的链表的头节点
*/
public Node reverseList(Node head) {
Stack<Node> stack = new Stack<>();
while (head != null) {
// 将节点压入栈中
stack.push(head);
// 移动到下一个节点
head = head.next;
}
// 新建一个头节点,用于反转链表
Node newHead = null;
// 循环出栈,反转链表
while (!stack.isEmpty()) {
// 弹出栈顶节点
Node node = stack.pop();
// 将节点next指针指向新的头节点,实现反转
node.next = newHead;
// 将新的头节点指向当前节点
newHead = node;
}
// 返回反转后的链表
return newHead;
}
阅读全文