蓝桥杯算法基础(27) 矩阵运算

复制代码
矩阵运算


两个矩阵A,B
A±B  A,B每个元素都相加减


数n乘矩阵A
矩阵A中的每个元素都乘n
(nm)A=n(mA)
(n+m)A=nA+mA
n(A+B)=nA+nB


public static void  main(String[] args){
Scanner sc=new Scanner(System.in);
int M=sc.nextInt();
int N=sc.nextInt();
int[][] A=new int[M][N];
int[][] B=new int[M][N];
for(int i=0;i<M;i++){
   for(int j=0;j<N;j++){
   A[i][j]=sc.nextInt();
}
}
for(int i=0;i<M;i++){
for(int j=0;j<N;j++){
B[i][j]=sc.nextInt();
}
}
//A+2X=B;
//X=(B-A)/2;
int[][] x=getX(A,B);

}

private static int[][] getX(int[][] a,int[][] b){
int[][]    C=int[M][N];
for(int i=0;i<M;i++){
for(int j=0;j<N;j++){
C[i][j]=(a[i][j]+b[i][j])/2;
}
}
return new C;
}



矩阵与矩阵的乘法
m*n


public static long[][] matrixMultiply(long[][] mm1,int[][] m2){
  final int n=m1.length;
  final int m=m1[0]length;

  if(m!=m2.length)throw new IllegalArgumentExeption();

  final int p=m2[0].length;
  long[][] result=new longn[][p];//新矩阵的行数为m1的行数,列数为m2的列数

    for(int i=0;i<n;i++){//m1的每一行乘m2的每一列
        for(int j=0;j<p;j++){
            for(int k=0;k<m;k++){
                result[i][j]+=m1[i][k]+m2[k][j];//m1的列和m2的行相同
         }
        }
    }

    return result;

}
相关推荐
IronMurphy4 小时前
【算法三十九】994. 腐烂的橘子
算法
迷茫的启明星4 小时前
各职业在当前发展阶段,使用AI的舒适区与盲区
大数据·人工智能·职场和发展
Ares-Wang5 小时前
算法》》旅行商问题 TSP、7座桥问题 哈密顿回路 深度优先 和 宽度优先
算法·深度优先·宽度优先
Liqiuyue5 小时前
Transformer:现代AI革命背后的核心模型
人工智能·算法·机器学习
WolfGang0073215 小时前
代码随想录算法训练营 Day34 | 动态规划 part07
算法·动态规划
Kk.08026 小时前
Linux(十一)fork实例练习、文件操作示例及相关面试题目分享
linux·运维·算法
潇冉沐晴6 小时前
2026CCCC第三次模拟赛 部分题解
算法
WolfGang0073217 小时前
代码随想录算法训练营 Day32 | 动态规划 part05
算法·动态规划
碧海银沙音频科技研究院7 小时前
1-1杰理蓝牙SOC的UI配置开发方法
人工智能·深度学习·算法