Java实现矩阵加减乘除及转制等运算功能示例

作者:miangangzhen 时间:2023-07-05 04:49:53 

本文实例讲述了Java实现矩阵加减乘除及转制等运算功能。分享给大家供大家参考,具体如下:

Java初学,编写矩阵预算程序,当做工具,以便以后写算法时使用。


public class MatrixOperation {
 public static int[][] add(int[][] matrix_a, int[][] matrix_b) {
   int row = matrix_a.length;
   int col = matrix_a[0].length;
   int[][] result = new int[row][col];
   if (row != matrix_b.length || col != matrix_b[0].length) {
     System.out.println("Fault");
   } else {
     for (int i = 0; i < row; i++) {
       for (int j = 0; j < col; j++) {
         result[i][j] = matrix_a[i][j] + matrix_b[i][j];
       }
     }
   }
   return result;
 }
 public static int[][] sub(int[][] matrix_a, int[][] matrix_b) {
   int row = matrix_a.length;
   int col = matrix_a[0].length;
   int[][] result = new int[row][col];
   if (row != matrix_b.length || col != matrix_b[0].length) {
     System.out.println("Fault");
   } else {
     for (int i = 0; i < row; i++) {
       for (int j = 0; j < col; j++) {
         result[i][j] = matrix_a[i][j] - matrix_b[i][j];
       }
     }
   }
   return result;
 }
 public static int[][] dot(int[][] matrix_a, int[][] matrix_b) {
   /*
    * matrix_a's dimention m*p matrix_b's dimention p*n. return dimention
    * m*n
    */
   int row = matrix_a.length;
   int col = matrix_a[0].length;
   int[][] result = new int[row][col];
   if (col != matrix_b.length) {
     System.out.println("Fault");
   } else {
     for (int i = 0; i < row; i++) {
       for (int j = 0; j < col; j++) {
         result[i][j] = 0;
         for (int k = 0; k < col; k++) {
           result[i][j] += matrix_a[i][k] * matrix_b[k][j];
         }
       }
     }
   }
   return result;
 }
 public static int[][] dot(int[][] matrix_a, int b) {
   int row = matrix_a.length;
   int col = matrix_a[0].length;
   int[][] result = new int[row][col];
   for (int i = 0; i < row; i++) {
     for (int j = 0; j < col; j++) {
       result[i][j] = matrix_a[i][j] * b;
     }
   }
   return result;
 }
 public static int[][] mul(int[][] matrix_a, int[][] matrix_b) {
   /*
    * matrix_a's dimention m*n matrix_b's dimention m*n. return dimention
    * m*n
    */
   int row = matrix_a.length;
   int col = matrix_a[0].length;
   int[][] result = new int[row][col];
   if (row != matrix_b.length || col != matrix_b[0].length) {
     System.out.println("Fault");
   } else {
     for (int i = 0; i < row; i++) {
       for (int j = 0; j < col; j++) {
         result[i][j] = matrix_a[i][j] * matrix_b[i][j];
       }
     }
   }
   return result;
 }
 public static int[][] transport(int[][] matrix_a) {
   int row = matrix_a.length;
   int col = matrix_a[0].length;
   int[][] result = new int[row][col];
   for (int i = 0; i < row; i++) {
     for (int j = 0; j < col; j++) {
       result[j][i] = matrix_a[i][j];
     }
   }
   return result;
 }
 public static void print(int[][] matrix) {
   int row = matrix.length;
   int col = matrix[0].length;
   for (int i = 0; i < row; i++) {
     System.out.print("[");
     for (int j = 0; j < col; j++) {
       System.out.print(matrix[i][j]);
       if (j != col - 1) {
         System.out.print(", ");
       }
     }
     System.out.print("]\n");
   }
 }
 public static void main(String[] args) {
   int[][] a = { { 1, 2 }, { 3, 4 } };
   int[][] b = { { 7, 8 }, { 6, 5 } };
   int[][] c = add(a, b);
   System.out.println("脚本之家测试结果如下:");
   System.out.println("matrix a = ");
   print(a);
   System.out.println("matrix b = ");
   print(b);
   System.out.println("matrix a + b = ");
   print(c);
   c = sub(a, b);
   System.out.println("matrix a - b = ");
   print(c);
   int[][] d = dot(a, b);
   System.out.println("matrix a dot b = ");
   print(d);
   int[][] e = dot(a, 3);
   System.out.println("matrix a * 3 = ");
   print(e);
   int[][] f = transport(a);
   System.out.println("matrix a.T = ");
   print(f);
   int[][] g = mul(a, b);
   System.out.println("matrix a * b = ");
   print(g);
 }
}

运行结果:

Java实现矩阵加减乘除及转制等运算功能示例

希望本文所述对大家java程序设计有所帮助。

来源:http://blog.csdn.net/miangangzhen/article/details/52275480

标签:Java,矩阵
0
投稿

猜你喜欢

  • C#基于简单工厂模式实现的计算器功能示例

    2023-06-19 12:40:10
  • c#代码自动修改解决方案下任意文件实例

    2023-01-31 07:27:10
  • Java实现中文算数验证码的实现示例(算数运算+-*/)

    2023-10-23 03:08:09
  • Android实现类似ios滑动按钮

    2023-06-26 11:17:48
  • Android隐藏顶部状态栏所遇到的问题

    2023-08-02 03:39:26
  • git版本回退_动力节点Java学院整理

    2022-06-21 13:26:10
  • 详解C# 虚方法virtual

    2022-11-05 09:41:17
  • idea install 时提示jdk的某个jar包的包不存在的问题

    2021-12-19 05:48:37
  • Android中Edittext设置输入条件

    2023-03-11 23:05:08
  • jmeter中json提取器如何提取多个参数值

    2022-08-10 00:08:27
  • android使用OPENGL ES绘制圆柱体

    2021-12-26 15:22:00
  • SpringBoot整合MyCat实现读写分离的方法

    2022-03-05 23:37:45
  • java中类与对象的使用详情

    2023-09-27 17:10:43
  • 详解Java关键字final

    2023-11-29 09:10:27
  • java并发编程工具类JUC之ArrayBlockingQueue

    2023-07-04 21:02:20
  • Android studio利用gradle打jar包并混淆的方法详解

    2021-07-07 06:22:57
  • SpringBoot中@ConditionalOnBean实现原理解读

    2023-04-25 14:24:54
  • Android开发中ImageLoder加载网络图片时将图片设置为ImageView背景的方法

    2021-12-14 14:58:38
  • java与JSON数据的转换实例详解

    2022-07-03 22:48:25
  • Java获取json数组对象的实例讲解

    2023-08-24 14:55:28
  • asp之家 软件编程 m.aspxhome.com