xtu oj矩阵

一开始

复制代码
#include<stdio.h>
int main(){
	int K;
	scanf("%d",&K);
	while(K--){
		int n,m;
		scanf("%d %d",&n,&m);
		int str[n+2][n+2];
		int t=1;
		for(int i=0;i<n;i++){
			for(int j=0;j<n;j++){
				str[i][j]=t++;
			}
		}//输入
	//	int flag=0;
		getchar();
		while(m--){
			char s;
			int x,y;
			scanf("%c %d %d",&s,&x,&y);
		//	printf("%c",s);
			if(s=='L'){
				while(y--){
					int cup=str[x-1][0];
					for(int i=1;i<n;i++){
						str[x-1][i-1]=str[x-1][i];
					}
					str[x-1][n-1]=cup;
					//flag=1;
				}
			}else if(s=='R'){
				while(y--){
					int cup=str[x-1][n-1];
					for(int i=n-2;i>=0;i--){
						str[x-1][i+1]=str[x-1][i];
					}
					str[x-1][0]=cup;
				}
			}else if(s=='U'){
				while(y--){
					int cup=str[0][x-1];
					for(int i=1;i<n;i++){
						str[i-1][x-1]=str[i][x-1];
					}
					str[n-1][x-1]=cup;
				}
			}else if(s=='D'){
				while(y--){
					int cup=str[n-1][x-1];
					for(int i=n-2;i>=0;i--){
						str[i+1][x-1]=str[i][x-1];
					}
					str[0][x-1]=cup;
				}
			}
			
		}
		for(int i=0;i<n;i++){
			for(int j=0;j<n;j++){
				printf("%d ",str[i][j]);
			}
		}
	//	printf("  flag=%d\n",flag);
		printf("\n");
	}
}

显然的,这个代码时间超限了,用空间换时间,所以构建一个中间数组temp[],可以一次执行y次移动,然后再存储在arr[]中

复制代码
#include <stdio.h>
#include <string.h>

#define MAXN 10

// 循环左移数组 arr 长度为 n,移动 y 次
void shift_left(int arr[], int n, int y) {
	y %= n;
	if (y == 0) return;
	int temp[MAXN];
	for (int i = 0; i < n; i++) {
		temp[i] = arr[(i + y) % n];
	}
	for (int i = 0; i < n; i++) {
		arr[i] = temp[i];
	}
}

// 循环右移数组 arr 长度为 n,移动 y 次
void shift_right(int arr[], int n, int y) {
	y %= n;
	if (y == 0) return;
	int temp[MAXN];
	for (int i = 0; i < n; i++) {
		temp[i] = arr[(i - y + n) % n];
	}
	for (int i = 0; i < n; i++) {
		arr[i] = temp[i];
	}
}

int main() {
	int K;
	scanf("%d", &K);
	
	while (K--) {
		int n, m;
		scanf("%d %d", &n, &m);
		
		// 初始化矩阵
		int mat[MAXN][MAXN];
		for (int i = 0; i < n; i++) {
			for (int j = 0; j < n; j++) {
				mat[i][j] = i * n + j + 1;
			}
		}
		
		// 处理每条指令
		for (int i = 0; i < m; i++) {
			char cmd[2];
			int x, y;
			scanf("%s %d %d", cmd, &x, &y);
			x--; // 转为0-based索引
			
			if (cmd[0] == 'L') {
				shift_left(mat[x], n, y);
			} else if (cmd[0] == 'R') {
				shift_right(mat[x], n, y);
			} else if (cmd[0] == 'U') {
				// 提取第x列
				int col[MAXN];
				for (int r = 0; r < n; r++) {
					col[r] = mat[r][x];
				}
				shift_left(col, n, y); // 上移 = 列左移
				for (int r = 0; r < n; r++) {
					mat[r][x] = col[r];
				}
			} else if (cmd[0] == 'D') {
				int col[MAXN];
				for (int r = 0; r < n; r++) {
					col[r] = mat[r][x];
				}
				shift_right(col, n, y); // 下移 = 列右移
				for (int r = 0; r < n; r++) {
					mat[r][x] = col[r];
				}
			}
		}
		
		// 按行输出结果
		int first = 1;
		for (int i = 0; i < n; i++) {
			for (int j = 0; j < n; j++) {
				if (!first) printf(" ");
				printf("%d", mat[i][j]);
				first = 0;
			}
		}
		printf("\n");
	}
	
	return 0;
}
相关推荐
NAGNIP3 小时前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
颜酱11 小时前
单调栈:从模板到实战
javascript·后端·算法
CoovallyAIHub14 小时前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub14 小时前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub14 小时前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉
CoovallyAIHub15 小时前
强化学习凭什么比监督学习更聪明?RL的“聪明”并非来自算法,而是因为它学会了“挑食”
深度学习·算法·计算机视觉
CoovallyAIHub15 小时前
YOLO-IOD深度解析:打破实时增量目标检测的三重知识冲突
深度学习·算法·计算机视觉
NAGNIP1 天前
轻松搞懂全连接神经网络结构!
人工智能·算法·面试
NAGNIP1 天前
一文搞懂激活函数!
算法·面试
董董灿是个攻城狮1 天前
AI 视觉连载7:传统 CV 之高斯滤波实战
算法