最近学习hadoop, 很多算法需要利用到矩阵计算,,例如: 协同过滤,pagerank 等等

所以练习一下,

	public  static void m1() {
		// 根据矩阵乘法的规则,a[4 *3]  * b[3,2],
		// 将会得到一个r [4 *2] 的新矩阵  
		//  r[i][j] = a[i][0] * b[0][j] + 
		//            a[i][1] * b[1][j] +
		//            a[i][2] * b[2][j]
		
		int[][] a = new int[][] { 
				{ 1, 2, 3 }, 
				{ 4, 5, 6 }, 
				{ 7, 8, 9 },
				{ 1, 2, 3} };
		
		int [][] b = new int[][]{
				{1,2},
				{3,4},
				{5,6} } ;
		
		int [][] r = new int[4][2];
		
		int tmp =0;
		
		// 结果集的列数, 多少列,就代表需要遍历a 矩阵多少次
		for ( int k =0; k < r[0].length; k++) {
			// 双重循环,遍历 a 矩阵
			for (int i = 0; i< a.length; i++ ) {
				tmp = 0;
				// 每一行的结果,对应结果集中的一个元素
				for (int j = 0; j < a[0].length; j++) {
					tmp += a[i][j] * b[j][k] ;
					
					
				}
				r[i][k]=tmp;
			}
		}

		for (int i = 0; i < r.length; i++) {
			for (int j = 0; j < r[0].length; j++) {
				System.out.print(r[i][j] + "\t");
			}
			System.out.println();
			
		}
	}