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

c求逆矩阵的代码_二维矩阵求逆刷石油大刷自闭了,随便写点乱七八糟的东西放松一下。。逆矩阵=伴随矩阵除以对应行列式的值,所以分别把这两个求出来就解决了,另外为了避免产生分数,就不做进一步计算了。效果图如下。至于代码。。就是把上次写的行列式求值的博客稍微改了一下,emmm。#include<stdio.h>#include<iostream>#pragmawarning(disa…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

 

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

#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.net/171665.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • django的drf框架的优点_一个类要具有可序列化

    django的drf框架的优点_一个类要具有可序列化前言上一篇文章我们讲述了序列化,这篇就带大家一起来实现以下序列化Serializer我们使用序列化类Serializer,我们来看下源码结构,这里推荐使用pycharm左边导航栏的Structu

    2022年7月31日
    8
  • supergo任我行纵行指南针TT硕点YY考勤打卡定位下载及安装教程

    supergo任我行纵行指南针TT硕点YY考勤打卡定位下载及安装教程**supergo指南针TT硕点YY定位下载及安装教程**supergo指南针TT硕点YY定位下载及安装教程(2021最新版更新)本文以supergo为例,演示说明下载过程1、首先登录supergo下载官网2、2.找到supergo下载的按钮。并点击下载,输入提示密码3.然后选择右上角三个点,选择在safari浏览器中打开。点击下载,安装。弹框请选择安装按钮4.点击设置-通用,描述文件和设备管理,找到证书名称,然后点击信任,即可…

    2022年6月25日
    83
  • python获取图像坐标点[通俗易懂]

    python获取图像坐标点[通俗易懂]importcv2importnumpyasnp#144621、142832、142836、142744、142739、142733、145448、#图片路径img=cv2.imread(‘./data/data/img/RK03AA8U142922_01_145435_ok.jpg’)a=[]b=[]defon_EVENT_LBUTTONDOWN(event,x,y,flags,param):ifevent==cv2.EVENT_LBUT

    2025年10月26日
    3
  • Kafka连接服务器出现:Connection to node 1 (localhost/127.0.0.1:9092) could not be established.「建议收藏」

    文章目录1.安全组是否开放&防火墙是否拦截请求2.登陆服务器查看Kafkabroker是否可用3.查看Kafka运行日志4.在网上找资料5.解决问题今天遇到个很奇怪的问题,是关于外网连接Kafka的。在服务器本地可以使用命令行参数连接并且进行发布订阅操作,但是在外网环境就不可以了,SpringBoot连接报错:Connectiontonode1(localhost/127….

    2022年4月11日
    89
  • 自定义web接收推送_Java Web

    自定义web接收推送_Java Webhttps://www.webjars.org/提供了很多js的jar,但是有时候有些js没有,我们也想打成jar,那怎么办?我们以jquery3.4.1版本为例子开始1.创建如下结构pom文件内容如下:<?xmlversion=”1.0″encoding=”UTF-8″?><projectxmlns=”http://maven.apache….

    2025年7月10日
    4
  • MAC 系统安装 Maven 及环境变量配置

    MAC 系统安装 Maven 及环境变量配置1、概述本文主要为在MAC苹果系统下安装Maven及环境变量配置Maven是Apache下的一个纯Java开发的开源项目。基于项目对象模型(缩写:POM)概念,Maven利用一个中央信息片断能管理一个项目的构建、报告和文档等步骤。Maven是一个项目管理工具,可以对Java项目进行构建、依赖管理。Maven也可被用于构建和管理各种项目,例如C#,Ruby,Scala和其他语言编写的项目。Maven曾是Jakarta项目的子项目,现为由Apache软件基金会主持

    2022年7月24日
    10

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号