`
xiangxuehai_jiaer
  • 浏览: 90112 次
  • 性别: Icon_minigender_2
  • 来自: 西安
社区版块
存档分类
最新评论

JAVA实现矩阵

阅读更多
import java.util.Random;

//矩阵类
public class Matrix {

	private int[][] matrix;

	Random random = new Random();

	// 构造方法
	public Matrix() {
		matrix = new int[3][3];

	}

	public Matrix(int n) {
		matrix = new int[n][n];

		for (int i = 0; i < n; i++) {
			for (int j = 0; j < n; j++) {
				matrix[i][j] = random.nextInt(100);
			}
		}
	}

	public Matrix(int n, int m) {
		matrix = new int[n][m];

		for (int i = 0; i < n; i++) {
			for (int j = 0; j < m; j++) {
				matrix[i][j] = random.nextInt(100);
			}
		}
	}

	public int[][] getMatrix() {
		return matrix;
	}

	// 输出矩阵中所有元素
	public void output() {
		for (int i = 0; i < matrix.length; i++) {
			for (int j = 0; j < matrix[i].length; j++) {
				System.out.print(matrix[i][j] + "\t");
			}
			System.out.println();
		}
	}

	// 求一个矩阵的转置矩阵
	public Matrix transpose() {

		int n = matrix.length;
		int m = matrix[0].length;

		Matrix transMatrix = new Matrix(n, m);

		for (int i = 0; i < n; i++) {
			for (int j = 0; j < m; j++) {
				transMatrix.getMatrix()[i][j] = matrix[j][i];
			}
		}

		return transMatrix;
	}

	// 判断一个矩阵是否为上三角矩阵
	public boolean isTriangular() {

		// 用相反的思路进行判断
		for (int i = 1; i < matrix.length; i++) {
			for (int j = 0; j < i; j++) {
				if (matrix[i][j] != 0) {
					return false;
				}
			}
		}

		return true;
	}

	// 判断是否为对称矩阵
	public boolean isSymmetry() {

		for (int i = 1; i < matrix.length; i++) {
			for (int j = 0; j < matrix[i].length; j++) {
				if (matrix[i][j] != matrix[j][i]) {
					return false;
				}
			}
		}

		return true;
	}

	// 矩阵的相加
	public void add(Matrix b) {

		int[][] matrixOfB = b.getMatrix();

		int n = matrixOfB.length;
		int m = matrixOfB[0].length;

		if (n != matrix.length || m != matrix[0].length) {
			System.out.println("矩阵的长度不一致,不能相加");
		} else {
			for (int i = 0; i < n; i++) {
				for (int j = 0; j < m; j++) {
					matrix[i][j] += matrixOfB[i][j];
				}
			}

		}
	}

	public static void main(String[] args) {

		//测试
		Matrix test1 = new Matrix(4);

		System.out.println("原始矩阵");
		test1.output();

		Matrix transMatrix = test1.transpose();

		System.out.println("转置矩阵");
		transMatrix.output();

		System.out.println("是否是上三角矩阵");
		System.out.println(test1.isTriangular());

		System.out.println("是否是对称矩阵");
		System.out.println(test1.isSymmetry());

		System.out.println("----------------------");

		Matrix test2 = new Matrix();

		test2.output();

		System.out.println(test2.isTriangular());
		System.out.println(test2.isSymmetry());
		
		System.out.println("----------------------");
		
		Matrix test3 = new Matrix(4);
		Matrix test4 = new Matrix(4);
		
		test3.add(test2);
		
		System.out.println("矩阵1");
		test3.output();
		System.out.println("矩阵2");
		test4.output();
		
		System.out.println("矩阵相加");
		test3.add(test4);
		
		test3.output();
	}

}

 

分享到:
评论
2 楼 南楚懿 2015-04-14  
1 楼 josico 2013-05-19  
矩阵 如何进行与操作呢?

相关推荐

Global site tag (gtag.js) - Google Analytics