BeginnersBook

  • Home
  • Java
    • Java OOPs
    • Java Collections
    • Java Examples
  • C
    • C Examples
  • C++
    • C++ Examples
  • DBMS
  • Computer Network
  • Python
    • Python Examples
  • More…
    • jQuery
    • Kotlin
    • WordPress
    • SEO
    • JSON
    • JSP
    • JSTL
    • Servlet
    • MongoDB
    • XML
    • Perl

How To Rotate A List In Java – Two Ways

Last Updated: December 1, 2024 by Chaitanya Singh | Filed Under: java

In this guide, you will learn how to rotate a list in Java. Rotation means shifting of elements, for example rotating a list to right by 2 position means 1st element becomes 3rd element, 2nd element becomes 4th element and so on. We will see two examples to rotate a list:

1. Using Collections.rotate()

You can use Collections.rotate() method to rotate a List. This method belongs to java.util.Collections class. Let’s see an example to understand the usage:

import java.util.Arrays;
import java.util.Collections;
import java.util.List;

public class RotateList {
public static void main(String[] args) {
List<Integer> list = Arrays.asList(1, 2, 3, 4, 5);
System.out.println("Original list: " + list);

// Rotate the list by 2 positions to the right
Collections.rotate(list, 2);
System.out.println("Rotated list: " + list);
}
}

In this example, the list [1, 2, 3, 4, 5] is rotated by 2 positions to the right, the output list is [4, 5, 1, 2, 3].

2. Manual Rotation

If you do not want to use the Collections.rotate() method, you can write a logic to manually rotate the list as shown below:

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

public class RotateListManual {
public static void main(String[] args) {
List<Integer> list = new ArrayList<>(Arrays.asList(1, 2, 3, 4, 5));
System.out.println("Original list: " + list);

// Rotate the list by 2 positions to the right
int k = 2;
rotate(list, k); // user defined method
System.out.println("Rotated list: " + list);
}

public static void rotate(List<Integer> list, int k) {
int size = list.size();
k = k % size; // In case k is greater than size of the list
if (k < 0) {
k += size; // In case k is negative
}

reverse(list, 0, size - 1);
reverse(list, 0, k - 1);
reverse(list, k, size - 1);
}

private static void reverse(List<Integer> list, int start, int end) {
while (start < end) {
Integer temp = list.get(start);
list.set(start, list.get(end));
list.set(end, temp);
start++;
end--;
}
}
}

The output is same as above. It is best to use the rotate() method instead of using this manual code, however sometimes, this logic is asked in interviews and tests.

Top Related Articles:

  1. StringJoiner toString() Method in Java
  2. Java Integer byteValue() Method
  3. Difference between local, instance and static variables in Java
  4. How to Compile and Run your First Java Program
  5. Java StringBuilder replace()

Tags: Java-ArrayList

About the Author

I have 15 years of experience in the IT industry, working with renowned multinational corporations. Additionally, I have dedicated over a decade to teaching, allowing me to refine my skills in delivering information in a simple and easily understandable manner.

– Chaitanya

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

Java Tutorial

Java Introduction

  • Java Index
  • Java Introduction
  • History of Java
  • Features of Java
  • C++ vs Java
  • JDK vs JRE vs JVM
  • JVM - Java Virtual Machine
  • First Java Program
  • Variables
  • Data Types
  • Operators

Java Flow Control

  • Java If-else
  • Java Switch-Case
  • Java For loop
  • Java while loop
  • Java do-while loop
  • Continue statement
  • break statement

Java Arrays

  • Java Arrays

OOPs Concepts

  • OOPs Concepts
  • Constructor
  • Java String
  • Static keyword
  • Inheritance
  • Types of inheritance
  • Aggregation
  • Association
  • Super Keyword
  • Method overloading
  • Method overriding
  • Overloading vs Overriding
  • Polymorphism
  • Types of polymorphism
  • Static and dynamic binding
  • Abstract class and methods
  • Interface
  • Abstract class vs interface
  • Encapsulation
  • Packages
  • Access modifiers
  • Garbage Collection
  • Inner classes
  • Static import
  • Static constructor

Java Exception Handling

  • Exception handling
  • Java try-catch
  • Java throw
  • Java throws
  • Checked and Unchecked Exceptions
  • Jav try catch finally
  • Exception Examples
  • Exception Propagation

Collections Framework

  • Collections in Java
  • Java ArrayList
  • Java LinkedList
  • Java Vector
  • Java HashSet
  • Java LinkedHashSet
  • Java TreeSet
  • Java HashMap
  • Java TreeMap
  • Java LinkedHashMap
  • Java Queue
  • Java PriorityQueue
  • Java Deque
  • Comparable interface
  • Comparator interface
  • Collections Interview Questions

MORE ...

  • Java Scanner Class
  • Java 8 Features
  • Java 9 Features
  • Java Conversion
  • Java Date
  • Java Multithreading
  • Java I/O
  • Java Serialization
  • Java Regex
  • Java AWT
  • Java Swing
  • Java Enum
  • Java Annotations
  • Java main method
  • Java Interview Q

Copyright © 2012 – 2025 BeginnersBook . Privacy Policy . Sitemap