蓝桥杯练习系统(算法训练)ALGO-932 低阶行列式计算

资源限制

内存限制:64.0MB C/C++时间限制:1.0s Java时间限制:3.0s Python时间限制:5.0s

问题描述

给出一个n阶行列式(1<=n<=9),求出它的值。

输入格式

第一行给出两个正整数n,p;

接下来n行,每行n个数,表示行列式,数据保证行列式中每个数绝对值不超过2*10^9。

输出格式

一个数表示行列式的值,答案对p取余(余数需要是非负数)。

样例输入

2 2

5 -4

2 -1

样例输出

1

部分数据范围

对于20%的数据n<=2

对于40%的数据n<=3

对于100%的数据n<=9,p<=40000。

cpp 复制代码
#include<iostream>
#include<math.h>
using namespace std;
const int N=15;
int a[N][N];
int p;

long long calc(int n,int a[N][N]){
	if(n==1){
		return a[1][1];
	}else if(n==2){
		return a[1][1]*a[2][2]-a[1][2]*a[2][1];
	} 
	//利用代数余子式求行列式
	//按第一行展开
	long long sum=0;
	for(int num=1;num<=n;num++){
		if(a[1][num]!=0){//等于0就不需要计算了 
			//求代数余子式
			int b_i=1;
			int b[N][N];
			for(int i=2;i<=n;i++){
				int b_j=1;
				for(int j=1;j<=n;j++){
					if(j!=num){
						b[b_i][b_j++]=a[i][j];
					}
				}
				b_i++;
			} 
			int det=calc(n-1,b);
			
			sum+=pow(-1,1+num)*a[1][num]*det;
			sum%=p;
		}
	} 
	return sum;
}
int main(){
	int n;
	cin>>n>>p;
	for(int i=1;i<=n;i++){
			for(int j=1;j<=n;j++){
				cin>>a[i][j];
				a[i][j]%=p;
			}
	}
	long long sum=calc(n,a);
	if(sum%p>=0){
		cout<<sum%p<<endl;
	}else{
		cout<<p+sum%p<<endl;
	}
	return 0;
} 

思路:利用代数余子式求行列式的值。

相关推荐
ytttr873几秒前
matlab进行利用遗传算法对天线阵列进行优化
开发语言·算法·matlab
一招定胜负2 分钟前
机器学习算法三:决策树
算法·决策树·机器学习
无限进步_2 分钟前
【C语言】队列(Queue)数据结构的实现与分析
c语言·开发语言·数据结构·c++·算法·链表·visual studio
李余博睿(新疆)13 分钟前
c++经典练习题-分支练习(2)
c++·算法
Dev7z14 分钟前
基于中心先验的全局对比度显著性检测算法
人工智能·算法·计算机视觉
重生之我是Java开发战士17 分钟前
【算法日记】排序算法:原理、实现、性能与应用
数据结构·算法·排序算法
啊阿狸不会拉杆27 分钟前
《数字图像处理》第 5 章-图像复原与重建
图像处理·人工智能·算法·matlab·数字图像处理
断剑zou天涯37 分钟前
【算法笔记】资源限制类题目的解题套路
笔记·算法·哈希算法
YoungHong19921 小时前
面试经典150题[074]:填充每个节点的下一个右侧节点指针 II(LeetCode 117)
leetcode·面试·职场和发展
元亓亓亓1 小时前
LeetCode热题100--763. 划分字母区间--中等
算法·leetcode·职场和发展