上海计算机学会2023年9月月赛C++丙组T2Z形填充

题目描述

给定一个整数 n,再给定 n2 个字符,请将这些字符以 z 形排成一个 n×n 的矩阵。

z 形的定义是,第一个字符在左上角,然后沿对角线以 z 形放置字符。对于 n=4 ,z 形排列的先后顺序标记如下:

输入格式
  • 第一行:单个整数表示 n
  • 第二行:n2 个可见字符表示给定的字符序列
输出格式
  • n 行 n 列个以 z 形排列的字符
数据范围
  • 50% 的数据,1≤n≤5
  • 100% 的数据,1≤n≤100
样例数据

输入:

5

abcdefghijklmnopqrstuvwxy

输出:

abfgo

cehnp

dimqv

jlruw

kstxy

题解

本题关键点:是随着斜边坐标加值的增加的,而且每个斜边能存放的数据数量先变多再变少。代码如下。

cpp 复制代码
#include<iostream>
#include<string>
using namespace std;
int main(){
	int n, x = 0;
	string s;
	cin >> n;
	//定义二维数组 
	char z[n + 1][n + 1];
	cin >> s;
	for(int y = 2; y <= 2 * n; y++){
		if(y % 2 == 0){
			for(int i = min(y - 1, n); i >= 1 && y - i <= n; i--){
				z[i][y - i] = s[x++];
			}
		}
		else{
			for(int j = min(y - 1, n); j >= 1 && y - j <= n; j--){
				z[y - j][j] = s[x++];
			}			
		}
	}
	for(int i = 1; i <= n; i++){
		for(int j = 1; j <= n; j++){
			cout << z[i][j];
		}
		cout << endl;
	}
	return 0;
}
相关推荐
那个村的李富贵7 小时前
CANN加速下的AIGC“即时翻译”:AI语音克隆与实时变声实战
人工智能·算法·aigc·cann
power 雀儿7 小时前
Scaled Dot-Product Attention 分数计算 C++
算法
琹箐8 小时前
最大堆和最小堆 实现思路
java·开发语言·算法
renhongxia18 小时前
如何基于知识图谱进行故障原因、事故原因推理,需要用到哪些算法
人工智能·深度学习·算法·机器学习·自然语言处理·transformer·知识图谱
坚持就完事了8 小时前
数据结构之树(Java实现)
java·算法
算法备案代理8 小时前
大模型备案与算法备案,企业该如何选择?
人工智能·算法·大模型·算法备案
赛姐在努力.9 小时前
【拓扑排序】-- 算法原理讲解,及实现拓扑排序,附赠热门例题
java·算法·图论
野犬寒鸦10 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
霖霖总总10 小时前
[小技巧66]当自增主键耗尽:MySQL 主键溢出问题深度解析与雪花算法替代方案
mysql·算法
rainbow688910 小时前
深入解析C++STL:map与set底层奥秘
java·数据结构·算法