Search
 
SCRIPT & CODE EXAMPLE
 

JAVA

Multiply two Strings Leetcode

/*
	This is an implementation that demonstrates
	how to efficiently multiply two int numbers
	that are represented as strings.

	Let M be the number of digits in first
	and N the number of digits in second.

	Time complexity: O(M*N) 
	Space complexity: O(M+N)
*/

public class MultiplyStrings {
	public static void main(String[] args) {
		String num1 = "123", num2 = "456";
		System.out.println(multiply(num1, num2)); // 56088
	}
	private static String multiply(String num1, String num2) {
		// If either is 0, return 0
		if (num1.equals("0") || num2.equals("0")) {
			return "0";
		}
		// Convert the numbers into StringBuilder objects
		StringBuilder firstNum = new StringBuilder(num1);
		StringBuilder secondNum = new StringBuilder(num2);

		// Reverse both numbers before performing the multiplication
		firstNum.reverse();
		secondNum.reverse();

		// Create answer variable as placeholder for
		// multiplication of each digit of firstNum with secondNum
		int N = firstNum.length() + secondNum.length();
		StringBuilder answer = new StringBuilder();
		for (int i = 0; i < N; i++) {
			answer.append("0");
		}
		int digit1, digit2;
		for (int place2 = 0; place2 < secondNum.length(); place2++) {
			digit2 = secondNum.charAt(place2) - '0';
			// Multiply current digit2 by all digits in firstNum
			for (int place1 = 0; place1 < firstNum.length(); place1++) {
				digit1 = firstNum.charAt(place1) - '0';
				// Current position in answer depends on place
				// of digit2 and place of digit1
				int currentPos = place1 + place2;
				// Digit currently at position currentPos is carried over
				// and summed with current result
				int carry = answer.charAt(currentPos) - '0';
				int product = digit1 * digit2 + carry;
				// Set the ones place of product
				answer.setCharAt(currentPos, (char) (product % 10 + '0'));
				// Add the carry to next position
				int value = (answer.charAt(currentPos + 1) - '0') +
						product / 10;
				answer.setCharAt(currentPos + 1, (char) (value + '0'));
			}
		}
		// Remove excess 0 from the rear of the answer
		if (answer.charAt(answer.length() - 1) == '0') {
			answer.deleteCharAt(answer.length() - 1);
		}
		answer.reverse();
		return answer.toString();
	}

}
Comment

PREVIOUS NEXT
Code Example
Java :: add certificate to java truststore 
Java :: gitignore java 
Java :: java check data type 
Java :: find duplicate value in array java 
Java :: how to close android app programmatically 
Java :: list of BigInteger to list of long 
Java :: java doreturn void 
Java :: java jcheckbox get value 
Java :: how to get index of second occurrence java 
Java :: java join list of strings 
Java :: java.lang.ExceptionInInitializerError: null 
Java :: How to validate a binary search tree, in Java? 
Java :: calculate mean from arraylist jaca 
Java :: text.settextcolor android 
Java :: encode file to base64 java 
Java :: arrays.fill java 
Java :: how to destroy activity in android 
Java :: how to iterate hashmap java 
Java :: bukkit Command sender is player 
Java :: spigot how to kill player 
Java :: rjava error 
Java :: byte to bufferedimage java 
Java :: remove extra spaces java 
Java :: android studio remove action bar 
Java :: how to format numbers in java 
Java :: java code samples 
Java :: android create snackbar 
Java :: min priority queue in java 
Java :: calling method in java 
Java :: how to use scanners in java 
ADD CONTENT
Topic
Content
Source link
Name
8+9 =