This is a java program to implement Wagner and Fisher Algorithm. In computer science, the Wagner–Fischer algorithm is a dynamic programming algorithm that computes the edit distance between two strings of characters.
Here is the source code of the Java Program to Implement Wagner and Fisher Algorithm for online String Matching. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
package com.maixuanviet.setandstring;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
public class WagnerandFischer
{
public int getLevenshteinDistance(String str1, String str2)
{
int len1 = str1.length();
int len2 = str2.length();
int[][] arr = new int[len1 + 1][len2 + 1];
for (int i = 0; i <= len1; i++)
arr[i][0] = i;
for (int i = 1; i <= len2; i++)
arr[0][i] = i;
for (int i = 1; i <= len1; i++)
{
for (int j = 1; j <= len2; j++)
{
int m = (str1.charAt(i - 1) == str2.charAt(j - 1)) ? 0 : 1;
arr[i][j] = Math.min(
Math.min(arr[i - 1][j] + 1, arr[i][j - 1] + 1),
arr[i - 1][j - 1] + m);
}
}
return arr[len1][len2];
}
public static void main(String[] args) throws IOException
{
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
System.out.println("Enter string 1 :");
String str1 = br.readLine();
System.out.println("Enter string 2 :");
String str2 = br.readLine();
WagnerandFischer wf = new WagnerandFischer();
int lDist = wf.getLevenshteinDistance(str1, str2);
System.out.println("Edit (Levenshtein) Distance between two strings = "
+ lDist);
br.close();
}
}
Output:
$ javac WagnerandFischer.java $ java WagnerandFischer Enter string 1 : Wagner and Fisher Algorithm Enter string 2 : Sanfoundry is No. 1 choice for Deep Hands-ON Trainings in SAN, Linux & C, Kernel & Device Driver Programming. Our Founder has trained employees of almost all Top Companies in India. Here are few of them: VMware, Citrix, Oracle, Motorola, Ericsson, Aricent, HP, Intuit, Microsoft, Cisco, SAP Labs, Siemens, Symantec, Redhat, Chelsio, Cavium Networks, ST Microelectronics, Samsung, LG-Soft, Wipro, TCS, HCL, IBM, Accenture, HSBC, Northwest Bank, Mphasis, Tata Elxsi, Tata Communications, Mindtree, Cognizant, mid size IT companies and many Startups. Students from top Universities and colleges such as NIT Trichy, BITS Pilani, University of California, Irvine, University of Texas, Austin & PESIT Bangalore have benefited a lot from these courses as well. The assignments and real time projects for our courses are of extremely high quality with excellent learning curve. Edit (Levenshtein) Distance between two strings = 844
Related posts:
New Features in Java 10
Java Program to Find the Vertex Connectivity of a Graph
Hướng dẫn tạo và sử dụng ThreadPool trong Java
Giới thiệu Swagger – Công cụ document cho RESTfull APIs
Lập trình đa luồng trong Java (Java Multi-threading)
Java Program to Implement Segment Tree
Java Program to Create a Random Graph Using Random Edge Generation
Java CyclicBarrier vs CountDownLatch
Java Program to Implement Bellman-Ford Algorithm
Apache Camel with Spring Boot
Hướng dẫn Java Design Pattern – Object Pool
Java Program to Perform Search in a BST
Java Program to Implement Gale Shapley Algorithm
How to Change the Default Port in Spring Boot
Spring Boot - Bootstrapping
Intersection of Two Lists in Java
Java Program to Check whether Undirected Graph is Connected using BFS
Deploy a Spring Boot WAR into a Tomcat Server
Spring WebClient Filters
Java Program to Generate Random Numbers Using Probability Distribution Function
Java Program to Use rand and srand Functions
Java Program to Perform Partial Key Search in a K-D Tree
Java 8 Predicate Chain
Phương thức tham chiếu trong Java 8 – Method References
Tính kế thừa (Inheritance) trong java
Java Program to Implement Hash Tree
Creating a Custom Starter with Spring Boot
Remove HTML tags from a file to extract only the TEXT
Hướng dẫn Java Design Pattern – Chain of Responsibility
Spring Security with Maven
Java Program to Print the Kind of Rotation the AVL Tree is Undergoing
Java Program to Generate Random Hexadecimal Byte