This is a java program to perform searching based on locality of refernce. The Locality of Reference principle says that if an element of a list is accessed it might also be accessed in near future. So we store it to the front of the list.
Here is the source code of the Java Program to Perform Searching Based on Locality of Reference. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
/*
* Follows recently accessed elements should be referred more so kept on top of
* the list
*/
package com.maixuanviet.combinatorial;
import java.util.LinkedList;
import java.util.List;
import java.util.Random;
import java.util.Scanner;
public class LocalityBasedSearching
{
public static void main(String[] args)
{
List<Integer> items = new LinkedList<Integer>();
Integer n = 10;
Scanner sc = new Scanner(System.in);
Random rand = new Random();
while (n > 0)
{
items.add(rand.nextInt(100));
n--;
}
System.out.println(items.toString());
boolean flag = true;
boolean found = false;
Integer numberofInstance;
while (flag == true)
{
numberofInstance = 0;
System.out.println("Enter the element to find: ");
Integer search = sc.nextInt();
for (int i = 0; i < items.size(); i++)
{
if (items.get(i).equals(search))
{
found = true;
System.out.println("Element found at index " + i
+ "\nReordering list...");
// Integer temp = items.get(numberofInstance);
// items.set(numberofInstance, search);
items.add(numberofInstance, search);
items.remove(i + 1);
// items.set(i, temp);
System.out.println("Reordered list: " + items.toString());
numberofInstance++;
// break;
}
}
if (found == false)
{
System.out.println("No such element found.");
}
System.out.println("Do you want to continue? <true>/<false>");
flag = sc.nextBoolean();
}
sc.close();
}
}
Output:
$ javac LocalityBasedSearching.java $ java LocalityBasedSearching [52, 94, 58, 8, 78, 0, 30, 81, 16, 58] Enter the element to find: 8 Element found at index 3 Reordering list... Reordered list: [8, 52, 94, 58, 78, 0, 30, 81, 16, 58] Do you want to continue? <true>/<false> true Enter the element to find: 58 Element found at index 3 Reordering list... Reordered list: [58, 8, 52, 94, 78, 0, 30, 81, 16, 58] Element found at index 9 Reordering list... Reordered list: [58, 58, 8, 52, 94, 78, 0, 30, 81, 16] Do you want to continue? <true>/<false> true Enter the element to find: 94 Element found at index 4 Reordering list... Reordered list: [94, 58, 58, 8, 52, 78, 0, 30, 81, 16] Do you want to continue? <true>/<false> false
Related posts:
Spring Security Login Page with React
Updating your Password
Java Program to Implement Lloyd’s Algorithm
New Features in Java 11
Finding Max/Min of a List or Collection
Java Deep Learning Essentials - Yusuke Sugomori
Java Program to Implement Max Heap
Java Program to Implement RoleList API
Java Program to Implement Triply Linked List
Java Program to Implement Ternary Search Algorithm
Spring Security Logout
The StackOverflowError in Java
Java Program to Implement Sorted Circular Doubly Linked List
Spring MVC Custom Validation
Java Program to implement Bi Directional Map
Java Program to Perform Postorder Recursive Traversal of a Given Binary Tree
Spring Security 5 for Reactive Applications
Hướng dẫn Java Design Pattern – Intercepting Filter
Java Program to Represent Graph Using Incidence Matrix
How to Define a Spring Boot Filter?
Spring Cloud AWS – Messaging Support
Java Program to Find Nearest Neighbor for Static Data Set
CyclicBarrier in Java
Understanding Memory Leaks in Java
Hướng dẫn sử dụng luồng vào ra ký tự trong Java
A Guide to the Java ExecutorService
Object Type Casting in Java
Java Program to Check Whether an Undirected Graph Contains a Eulerian Path
Java Program to Print the Kind of Rotation the AVL Tree is Undergoing
Find the Registered Spring Security Filters
Service Registration with Eureka
So sánh Array và ArrayList trong Java