C++ //CCF-CSP计算机软件能力认证 202406-1 矩阵重塑(其一)

CCF-CSP计算机软件能力认证 202406-1

矩阵重塑(其一)

题目背景

矩阵(二维)的重塑(reshape)操作是指改变矩阵的行数和列数,同时保持矩阵中元素的总数不变。

题目描述

矩阵的重塑操作可以具体定义为以下步骤:

设原矩阵为 M M M,其维度为 n × m n \times m n×m,即有 n n n行和 m m m列。新矩阵为 M ′ M' M′,其维度为 p × q p \times q p×q。重塑操作要满足 n × m = p × q n \times m = p \times q n×m=p×q,这保证了元素的总数不变。

  1. 线性化原矩阵: 按照行优先的顺序,将原矩阵 M M M的元素转换成一个长度为 n × m n \times m n×m的一维数组 A A A。这意味着你先读取 M M M的第 0 0 0行元素,然后是第 1 1 1行,依此类推,直到最后一行。
  2. 填充新矩阵: 使用一维数组 A A A中的元素按照行优先的顺序填充新矩阵 M ′ M' M′。首先填充 M ′ M' M′的第 0 0 0行,直到该行有 q q q个元素,然后继续填充第 1 1 1行,直到所有 p p p行都被填满。

给定原矩阵中的一个元素的位置 ( i , j ) ( 0 ≤ i < n 且 0 ≤ j < m ) (i, \ j)\ (0 \le i \lt n 且 0 \le j \lt m) (i, j) (0≤i<n且0≤j<m),我们可以找到这个元素在被线性化后的一维数组 A A A中的位置 k ( 0 ≤ k < n × m ) k\ (0 \le k \lt n \times m) k (0≤k<n×m),然后确定它在新矩阵 M ′ M' M′中的位置 ( i ′ , j ′ ) ( 0 ≤ i ′ < p 且 0 ≤ j < q ) (i', \ j') \ (0 \le i' \lt p 且 0 \le j \lt q) (i′, j′) (0≤i′<p且0≤j<q)。它们之间满足如下数学关系:
i × m + j = k = i ′ × q + j ′ i \times m + j = k = i' \times q + j' i×m+j=k=i′×q+j′

给定 n × m n \times m n×m的矩阵 M M M和目标形状 p p p、 q q q,试将 M M M重塑为 p × q p \times q p×q的矩阵 M ′ M' M′。

输入格式

从标准输入读入数据。

输入共 n + 1 n+1 n+1行。

输入的第一行包含四个正整数 n n n、 m m m和 p p p、 q q q。

接下来依次输入原矩阵 M M M的第 0 0 0到第 n − 1 n-1 n−1行,每行包含 m m m个整数,按列下标从 0 0 0到 m − 1 m-1 m−1的顺序依次给出。

输出格式

输出到标准输出。

输出共 p p p行,每行 q q q个整数,表示重塑后的矩阵 M ′ M' M′。输出格式与输入相同,即依次输出 M ′ M' M′的第 0 0 0行到第 p − 1 p-1 p−1行;行内按列下标从 0 0 0到 q − 1 q-1 q−1的顺序输出,且两个整数间仅用一个空格分隔。

样例1输入

2 3 3 2

1 2 3

4 5 6

样例1输出

1 2

3 4

5 6

样例2输入

2 2 1 4

6 6

6 6

样例2输出

6 6 6 6

子任务

全部的测试数据满足:

  • n n n、 m m m和 p p p、 q q q均为正整数且 n × m = p × q ≤ 1 0 4 n \times m = p \times q \le 10^4 n×m=p×q≤104;
  • 输入矩阵中每个元素的绝对值不超过1000。
环境:Linux Ubuntu(云服务器)
工具:vim
代码块:
cpp 复制代码
/*************************************************************************
	> File Name: ex20240601.cpp
	> Author: 
	> Mail: 
	> Created Time: Fri 14 Jun 2024 02:39:03 PM CST
 ************************************************************************/

#include<iostream>
using namespace std;

void initialMatrix(int n, int m, int ***matrix){
	*matrix = (int**)malloc(n * sizeof(int*));
	for(int i = 0; i < n; i++){
		(*matrix)[i] = (int*)malloc(m * sizeof(int));
	}
}

void freeMatrix(int n, int m, int ***matrix){
	for(int i = 0; i < n; i++){
		free((*matrix)[i]);
	}
	free(*matrix);
}

void inputMatrix(int n, int m, int **matrix){
	for(int i = 0; i < n; i++){
		for(int j = 0; j < m; j++){
			cin>>matrix[i][j];
		}
	}
}

void outputMatrix(int p, int q, int **matrix){
	for(int i = 0; i < p; i++){
		for(int j = 0; j < q; j++){
			cout<<matrix[i][j]<<" ";
		}
		cout<<endl;
	}
}

void reshape(int n, int m, int p, int q, int **matrix, int **newMatrix){
	int total = n * m;
	int *temp = (int*)malloc(total * sizeof(int));

	for(int i = 0, k = 0; i < n; i++){
		for(int j = 0; j < m; j++){
			temp[k++] = matrix[i][j];
		}
	}

	for(int i = 0, k = 0; i < p; i++){
		for(int j = 0; j < q; j++){
			newMatrix[i][j] = temp[k++];
		}
	}

	free(temp);
}

int main(){
	int n, m, p, q;
	int **matrix = NULL;
	int **newMatrix = NULL;

	cin>>n>>m>>p>>q;

	initialMatrix(n, m, &matrix);
	inputMatrix(n, m, matrix);

	initialMatrix(p, q, &newMatrix);
	reshape(n, m, p, q, matrix, newMatrix);

	outputMatrix(p, q, newMatrix);

	freeMatrix(n, m, &matrix);
	freeMatrix(p, q, &newMatrix);

	return 0;
}
运行结果显示如下
相关推荐
做怪小疯子4 分钟前
LeetCode 热题 100——链表——相交链表
算法·leetcode·链表
喵个咪1 小时前
Qt 6 实战:C++ 调用 QML 回调方法(异步场景完整实现)
前端·c++·qt
立志成为大牛的小牛1 小时前
数据结构——五十一、散列表的基本概念(王道408)
开发语言·数据结构·学习·程序人生·算法·散列表
Coovally AI模型快速验证2 小时前
去噪扩散模型,根本不去噪?何恺明新论文回归「去噪」本质
人工智能·深度学习·算法·机器学习·计算机视觉·数据挖掘·回归
歌_顿2 小时前
attention、transform、bert 复习总结 1
人工智能·算法
MicroTech20252 小时前
MLGO微算法科技时空卷积与双重注意机制驱动的脑信号多任务分类算法
科技·算法·分类
txp玩Linux3 小时前
rk3568上解析webrtc音频降噪算法处理流程
算法·音视频·webrtc
立志成为大牛的小牛3 小时前
数据结构——五十二、散列函数的构造(王道408)
数据结构·笔记·程序人生·考研·算法
希望有朝一日能如愿以偿4 小时前
力扣每日一题:可被三整除的最大和
数据结构·算法·leetcode
阿波茨的鹅4 小时前
VSCode C++ 项目配置教程
c++·ide·vscode