$show=/label

Java Program to Multiply two Matrix Using Multi-dimensional Arrays

SHARE:

A quick and practical guide to multiply two matrices in java using multi dimensional array with 3 for loops. Example program without using threads.

1. Overview

In this tutorial, you'll learn how to multiply two matrix in java using multi dimensional arrays.

To understand this example program, it is better to know the following concepts.

Arrays - How to Initialize Arrays

For Loops Examples

Java Program to Multiply two Matrix Using Multi-dimensional Arrays


One condition must be satisfied for matrix multiplication as below.

First matrix order: R1 X C1

Second matrix order: R2 X C2

Always C1 and R2 must be same number that means number of columns in matrix 1 should be equal to the number of rows in the second matrix.

If this condition is not satisfied then matrix multiplication is not possible.

And also output matrix order will be R1 X C2.

2. Example Program To Multiply Two Matrices

Let us understand the below program that uses 3 for loops and with time complexity of Big O of n cube (O(n3)).

package com.javaprogramto.programs.arrays.matrix;

public class MatrixMultiplication {

	public static void main(String[] args) {
		// creating the first matrix using arrays
		int[][] matrix1 = { { 1, 2, 3 }, { 4, 5, 6 } };

		// creating the second matrix using two dimension array
		int[][] matrix2 = { { 1, 1 }, { 1, 1 }, { 1, 1 } };

		// Matrix 1 rows and columns length
		int rows1 = matrix1.length;
		int columns1 = matrix1[0].length;

		// Matrix 2 rows and columns length
		int rows2 = matrix2.length;
		int columns2 = matrix2[1].length;

		// output array for storing the multiplication result
		int[][] result = new int[rows1][columns2];

		// matrix addition core logic
		for (int i = 0; i < rows1; i++) {
			for (int j = 0; j < columns2; j++) {
				for (int k = 0; k < columns1; k++) {
					result[i][j] += matrix1[i][k] * matrix2[k][j];
				}
			}
		}

		// printing the result
		for (int i = 0; i < result.length; i++) {
			for (int j = 0; j < result[1].length; j++) {
				System.out.print(result[i][j] + " ");
			}
			System.out.println();
		}

	}

}


 

Output:

6 6 
15 15 

 

This examples works well for smaller inputs but if the order of these matrix's are 10 X 10 or 30 X 30 then it will give worst performance. So, you should optimize the code using multithreading.

Next article on Java Matrix Multiplication with multiple threads

3. Conclusion

In this article, you've seen how to multiply two matrices in java with using 3 for loops.

As usual, example shown is over GitHub.

Ref

COMMENTS

BLOGGER

About Us

Author: Venkatesh - I love to learn and share the technical stuff.
Name

accumulo,1,ActiveMQ,2,Adsense,1,API,37,ArrayList,16,Arrays,16,Bean Creation,3,Bean Scopes,1,BiConsumer,1,Blogger Tips,1,Books,1,C Programming,1,Collection,5,Collections,23,Collector,1,Command Line,1,Compile Errors,1,Configurations,7,Constants,1,Control Statements,8,Conversions,6,Core Java,84,Corona India,1,Create,2,CSS,1,Date,3,Date Time API,12,Dictionary,1,Difference,1,Download,1,Eclipse,2,Efficiently,1,Error,1,Errors,1,Exception,1,Exceptions,3,Fast,1,Files,10,Float,1,Font,1,Form,1,Freshers,1,Function,3,Functional Interface,2,Garbage Collector,1,Generics,4,Git,4,Grant,1,Grep,1,HashMap,1,HomeBrew,2,HTML,2,HttpClient,2,Immutable,1,Installation,1,Interview Questions,5,Iterate,2,Jackson API,3,Java,30,Java 10,1,Java 11,5,Java 12,5,Java 13,2,Java 14,2,Java 8,77,Java 8 Difference,2,Java 8 Stream Conversions,2,java 8 Stream Examples,3,Java 9,1,Java Conversions,11,Java Design Patterns,1,Java Files,1,Java Program,3,Java Programs,93,java.lang,5,java.util. function,1,jQuery,1,Kotlin,10,Kotlin Conversions,3,Kotlin Programs,6,Lambda,1,lang,29,Leap Year,1,live updates,1,Logging,1,Mac OS,2,Math,1,Matrix,5,Maven,1,Method References,1,Mockito,1,MongoDB,3,New Features,1,Operations,1,Optional,6,Oracle,5,Oracle 18C,1,Partition,1,Patterns,1,Programs,1,Property,1,Python,2,Quarkus,1,Read,1,Real Time,1,Recursion,2,Remove,2,Rest API,1,Schedules,1,Serialization,1,Servlet,2,Sort,1,Sorting Techniques,8,Spring,2,Spring Boot,23,Spring Email,1,Spring MVC,1,Streams,23,String,58,String Programs,12,String Revese,1,Swing,1,System,1,Tags,1,Threads,10,Tomcat,1,Tomcat 8,1,Troubleshoot,16,Unix,2,Updates,3,util,5,While Loop,1,
ltr
item
JavaProgramTo.com: Java Program to Multiply two Matrix Using Multi-dimensional Arrays
Java Program to Multiply two Matrix Using Multi-dimensional Arrays
A quick and practical guide to multiply two matrices in java using multi dimensional array with 3 for loops. Example program without using threads.
https://1.bp.blogspot.com/-1j84Tl0Tvak/X5XAvI3n0vI/AAAAAAAAC_Y/zbQfyU6zzzwuIpK86Fslz1IapqJancJ4gCLcBGAsYHQ/w640-h398/Java%2BProgram%2Bto%2BMultiply%2Btwo%2BMatrix%2BUsing%2BMulti-dimensional%2BArrays.png
https://1.bp.blogspot.com/-1j84Tl0Tvak/X5XAvI3n0vI/AAAAAAAAC_Y/zbQfyU6zzzwuIpK86Fslz1IapqJancJ4gCLcBGAsYHQ/s72-w640-c-h398/Java%2BProgram%2Bto%2BMultiply%2Btwo%2BMatrix%2BUsing%2BMulti-dimensional%2BArrays.png
JavaProgramTo.com
https://www.javaprogramto.com/2020/10/java-program-to-multiply-two-matrix-using-arrays.html
https://www.javaprogramto.com/
https://www.javaprogramto.com/
https://www.javaprogramto.com/2020/10/java-program-to-multiply-two-matrix-using-arrays.html
true
3124782013468838591
UTF-8
Loaded All Posts Not found any posts VIEW ALL Readmore Reply Cancel reply Delete By Home PAGES POSTS View All RECOMMENDED FOR YOU LABEL ARCHIVE SEARCH ALL POSTS Not found any post match with your request Back Home Sunday Monday Tuesday Wednesday Thursday Friday Saturday Sun Mon Tue Wed Thu Fri Sat January February March April May June July August September October November December Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec just now 1 minute ago $$1$$ minutes ago 1 hour ago $$1$$ hours ago Yesterday $$1$$ days ago $$1$$ weeks ago more than 5 weeks ago Followers Follow THIS PREMIUM CONTENT IS LOCKED STEP 1: Share to a social network STEP 2: Click the link on your social network Copy All Code Select All Code All codes were copied to your clipboard Can not copy the codes / texts, please press [CTRL]+[C] (or CMD+C with Mac) to copy Table of Content