tell me how to reverse a linked list in java
Sure! Here's an example of how to reverse a singly linked list in Java:

```java
public class ListNode {
    int val;
    ListNode next;
    ListNode(int x) { val = x; }
}

public class ReverseLinkedList {
    public ListNode reverseList(ListNode head) {
        ListNode prev = null;
        ListNode curr = head;
        while (curr != null) {
            ListNode nextNode = curr.next;
            curr.next = prev;
            prev = curr;
            curr = nextNode;
        }
        return prev;
    }
}
```
In this code, ListNode represents the nodes of the linked list, and each ListNode object has an integer value and a next pointer that points to the next node in the list.

The ReverseLinkedList class contains the reverseList() method, which takes the head of the linked list as an input and returns the new head of the reversed list. The algorithm works by iterating through the list with two pointers (prev and curr). In each iteration, the next pointer of the current node is updated to point to the previous node, and the prev and curr pointers are moved one node forward. When the iteration is complete, the prev pointer will be pointing to the new head of the reversed list, so it is returned as the output.

Note that this implementation is for a singly linked list, where each node only has a next pointer. If you have a doubly linked list (where each node has both prev and next pointers), the algorithm would be slightly different.