矩阵转置

本文介绍如何通过一维数组实现矩阵转置。矩阵转置过程中,原矩阵的第 i 行第 j 列元素在转置后变为第 j 行第 i 列。在行主序存储的条件下,元素的原始位置下标为 (i-1)*n + (j-1),转置后变为 (j-1)*n + (i-1)。

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

原题:已知一矩阵matrix[n*n]按行主序优先存储于一维数组 array[0:n*n] 中,试编写算法将 matrix 转置且仍存储于 array 中.
分析:矩阵转置的含义就是将矩阵中第 i 行第 j 列的元素交换,对于 matrix 中的元素 matrix[i][j], 转置前它在 array 中的下标是 (i-1)*n + (j-1), 转置后它在 array 中的下标为 (j-1)*n + (i-1).

#include<iostream>
#include<time.h>
#include<iomanip>//控制输出格式的头文件

#define N 5
#define ElemType int

using namespace std;

ElemType CreateMatrix(ElemType array[],int n)
{//生成一个数据元素随机生成数组,用于测试
	int i,k;
	srand((unsigned)time(NULL));

	for(i=0; i < n * n; i++)
	{
			k=rand()%100 + 9;
			cout.width(4);//设置数字输出时的宽度,每一次输出都要设置
			cout<<k;
			array[i] = k;
			if(0 == (i+1)%N)
			{
				cout<<endl<<endl;
			}
	}
	cout<<endl;
	return 1;
}
void Transpose(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Storm-Shadow

你的鼓励将是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值