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:
Getting the Size of an Iterable in Java
Hướng dẫn sử dụng lớp Console trong java
Java – InputStream to Reader
JavaScript Sticky flag "y", searching at position
Java Program to Implement DelayQueue API
Java Program to Compute DFT Coefficients Directly
Join and Split Arrays and Collections in Java
Spring Web Annotations
DistinctBy in the Java Stream API
OAuth2 for a Spring REST API – Handle the Refresh Token in AngularJS
Guide to @ConfigurationProperties in Spring Boot
Java Program to Implement the MD5 Algorithm
Java IO vs NIO
Java Program to Implement Trie
Introduction to PCollections
Spring Boot - Quick Start
Jackson Unmarshalling JSON with Unknown Properties
Spring Cloud AWS – S3
Using the Not Operator in If Conditions in Java
Circular Dependencies in Spring
REST Web service: Upload và Download file với Jersey 2.x
Spring Boot: Customize Whitelabel Error Page
Tính trừu tượng (Abstraction) trong Java
Java Program to Implement Quick Sort Using Randomization
Java Program to Implement Sorted List
Spring Boot - Building RESTful Web Services
How to Return 404 with Spring WebFlux
Java Program to Implement Slicker Algorithm that avoids Triangulation to Find Area of a Polygon
Supplier trong Java 8
Java Program to Implement Binary Heap
Dynamic Proxies in Java
Spring MVC Tutorial