斯特拉森矩阵乘法

这是一个使用Java实现斯特拉森矩阵乘法的程序。通过递归方式将矩阵拆分、运算并合并,该方法在矩阵大小超过36时相比传统乘法能显著提高效率。虽然递归过程复杂,但完成后的代码让作者对矩阵运算有了更深的理解。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

先上代码
package Sort;
public class Matrix {

	public static void main(String[] args) {
		int[][] cc={
  
  {1,1,1,1,1,1,1,1},{1,1,1,1,1,1,1,1},{1,1,1,1,1,1,1,1},{1,1,1,1,1,1,1,1},{1,1,1,1,1,1,1,1},{1,1,1,1,1,1,1,1},{1,1,1,1,1,1,1,1},{1,1,1,1,1,1,1,1}};
		int[][] e =new Matrix().multiMatrix(cc,cc);
		for(int i=0;i<e.length;i++)
		{
			for(int j=0;j<e.length;j++)
				System.out.print(e[i][j]+" ");
			System.out.println();
		}
		
	}
	int[][] multiMatrix(int[][] x,int[][] y)//矩阵的乘法
	{
		Matrix matr=new Matrix();
		int a=x.length/2;
		if(x.length==2)
		{
			int m1=(x[0][1]-x[1][1])*(y[1][0]+y[1][1]),
				m2=(x[0][0]+x[1][1])*(y[0][0]+y[0][1]),
				m3=(x[1][0]-x[0][0])*(y[0][0]+y[0][1]),
				m4=(x[0][0]+x[0][1])*y[1][1],
				m5=x[0][0]*(y[0][1]-y[1][1]),
				m6=x[1][1]*(y[1][0]-y[0][0]),
				m7=(x[1][0]+x[1][1])*y[0][0];
			int[][] c=new int[2][2];
			c[0][0]=m1+m2+m6-m4;
			c[0][1]=m4+m5;
			c[1][0]=m6+m7;
			c[1][1]=m2+m3+m5-m7;
			return c;			
		}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值