This Java program is to Implement Sparse array. In computer science, a sparse array is an array in which most of the elements have the same value (known as the default value—usually 0 or null). The occurrence of zero elements in a large array is inefficient for both computation and storage. An array in which there is a large number of zero elements is referred to as being sparse.
Here is the source code of the Java program to implement sparse array. The Java program is successfully compiled and run on a Linux system. The program output is also shown below.
class List
{
private int index;
private Object value;
private List nextindex;
public List(int index)
{
this.index = index;
nextindex = null;
value = null;
}
public List()
{
index = -1;
value = null;
nextindex = null;
}
public void store(int index, Object value)
{
List current = this;
List previous = null;
List node = new List(index);
node.value = value;
while (current != null && current.index < index)
{
previous = current;
current = current.nextindex;
}
if (current == null)
{
previous.nextindex = node;
} else
{
if (current.index == index)
{
System.out.println("DUPLICATE INDEX");
return;
}
previous.nextindex = node;
node.nextindex = current;
}
return;
}
public Object fetch(int index)
{
List current = this;
Object value = null;
while (current != null && current.index != index)
{
current = current.nextindex;
}
if (current != null)
{
value = current.value;
} else
{
value = null;
}
return value;
}
public int elementCount()
{
int elementCount = 0;
for (List current = this.nextindex; (current != null); current = current.nextindex)
{
elementCount++;
}
return elementCount;
}
}
public class SparseArray
{
private List start;
private int index;
SparseArray(int index)
{
start = new List();
this.index = index;
}
public void store(int index, Object value)
{
if (index >= 0 && index < this.index)
{
if (value != null)
start.store(index, value);
} else
{
System.out.println("INDEX OUT OF BOUNDS");
}
}
public Object fetch(int index)
{
if (index >= 0 && index < this.index)
return start.fetch(index);
else
{
System.out.println("INDEX OUT OF BOUNDS");
return null;
}
}
public int elementCount()
{
return start.elementCount();
}
public static void main(String... arg)
{
Integer[] iarray = new Integer[5];
iarray[0] = 1;
iarray[1] = null;
iarray[2] = 2;
iarray[3] = null;
iarray[4] = null;
SparseArray sparseArray = new SparseArray(5);
for (int i = 0; i < iarray.length; i++)
{
sparseArray.store(i, iarray[i]);
}
System.out.println("NORMAL ARRAY");
for (int i = 0 ; i < iarray.length; i++)
{
System.out.print(iarray[i] + "\t");
}
System.out.println("\nSPARSE ARRAY");
for (int i = 0; i < iarray.length; i++)
{
if (sparseArray.fetch(i) != null)
System.out.print(sparseArray.fetch(i) + "\t");
}
System.out.println("The Size of Sparse Array is " + sparseArray.elementCount());
}
}
$javac SparseArray.java $java SparseArray NORMAL ARRAY 1 null 2 null null SPARSE ARRAY 1 2 The Size of Sparse Array 2
Related posts:
Explain about URL and HTTPS protocol
Java Program to Generate Random Partition out of a Given Set of Numbers or Characters
Quick Guide to Spring MVC with Velocity
Shuffling Collections In Java
Lập trình mạng với java
Java Program to Implement Hash Tables Chaining with Binary Trees
HttpClient Basic Authentication
Retrieve User Information in Spring Security
Spring Boot - Apache Kafka
Generate Spring Boot REST Client with Swagger
Tìm hiểu về xác thực và phân quyền trong ứng dụng
Copy a List to Another List in Java
Use Liquibase to Safely Evolve Your Database Schema
Từ khóa throw và throws trong Java
Spring Boot - CORS Support
REST Pagination in Spring
Java Program to Implement Pagoda
LinkedList trong java
Tiêu chuẩn coding trong Java (Coding Standards)
Guide to Spring @Autowired
Java – Reader to Byte Array
Java Program to Use Above Below Primitive to Test Whether Two Lines Intersect
Java Program to Implement Hash Trie
Java Program to Implement Direct Addressing Tables
Quick Guide to Spring Bean Scopes
Ép kiểu trong Java (Type casting)
Java TreeMap vs HashMap
Spring WebClient vs. RestTemplate
Cài đặt và sử dụng Swagger UI
Java Program to Implement Control Table
ExecutorService – Waiting for Threads to Finish
How to Iterate Over a Stream With Indices