首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >c求逆矩阵的代码_二维矩阵求逆

c求逆矩阵的代码_二维矩阵求逆

作者头像
全栈程序员站长
发布2022-09-27 21:27:07
发布2022-09-27 21:27:07
1.2K0
举报

大家好,又见面了,我是你们的朋友全栈君。

代码语言:javascript
复制
#include<stdio.h>
#include<iostream>
#pragma warning(disable : 4996)

using namespace std;

const int maxn=105;

int juzhen[maxn][maxn],n;
int ans[maxn][maxn];
int book[maxn];
int nx(int n)
{
	int sum = 0;
	for (int i = 0; i < n; i++)
	{
		for (int j = 0; j < i; j++)
		{
			if (book[j] > book[i]) sum++;
		}
	}
	if (sum & 1) return -1;
	return 1;
}
int yuzi_ans;
void dfs(int yuzi[maxn][maxn], int sum, int pos,int n) {
	if (sum == n ) {
		int s = 1;
		for (int i = 0; i < n; i++) s *= yuzi[i][book[i]];
		yuzi_ans += nx(n) * s;
		return;
	}
	for (int i = 0; i < n; i++)
	{
		if (pos >> i & 1) continue;
		pos = pos | 1 << i;
		book[sum] = i;
		dfs(yuzi,sum + 1,pos,n);
		pos = pos ^ 1 << i;
	}
}
int f(int yuzi[maxn][maxn],int n) {
	yuzi_ans = 0;
	dfs(yuzi, 0, 0,n);
	return yuzi_ans;
}
void nijuzhen() {
	int yuzi[maxn][maxn];
	int bansui[maxn][maxn];
	for (int i = 0; i < n; i++) {
		for (int j = 0; j < n; j++) {
			int p = 0;
			for (int k = 0; k < n - 1; k++) {
				if (p == i) {
					p++;
				}
				int q = 0;
				for (int r = 0; r < n - 1; r++) {
					if (q == j) {
						q++;
					}
					yuzi[k][r] = juzhen[p][q++];
				}
				p++;
			}
			int flag = 1;
			if ((i + j) & 1) flag = -1;
			bansui[j][i] = f(yuzi,n-1)*flag;
		}
	}
	printf("伴随矩阵为:\n");
	for (int i = 0; i < n; i++) {
		for (int j = 0; j < n; j++) {
			printf("%d ", bansui[i][j]);
		}
		printf("\n");
	}
	printf("原矩阵对应的行列式的值为:\n");
	printf("%d", f(juzhen, n));
}

int main()
{
	printf("请输入矩阵阶数\n");
	scanf("%d", &n);
	for (int i = 0; i < n; i++)
		for (int j = 0; j < n; j++)
			scanf("%d", &juzhen[i][j]);
	nijuzhen();
	return 0;
}

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/171665.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年8月21日 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档