OJ_重复者

题干




C++实现

cpp 复制代码
#include <stdio.h>
#include <string.h>
using namespace std;
void square(int curSize, int patSize, char pattern[3000][3000], char picture[3000][3000], char last[3000][3000]) {
	if (curSize == 1) {
		for (int i = 0; i < patSize; ++i) {
			for (int j = 0; j < patSize; ++j) {
				picture[i][j] = pattern[i][j];
			}
		}
	} else {
		// 根据模板的字符是否为空格进行分形处理

		for (int i = 0; i < patSize; ++i) {
			for (int j = 0; j < patSize; ++j) {
				if (pattern[i][j] == ' ') {
					for (int pi = i * curSize; pi < i * curSize + curSize; ++pi) {
						for (int pj = j * curSize; pj < j * curSize + curSize; ++pj) {
							picture[pi][pj] = ' ';
						}
					}
				} else {
					// 这里需要建立新图案和模板的下标映射关系
					for (int pi = i * curSize; pi < i * curSize + curSize; ++pi) {
						for (int pj = j * curSize; pj < j * curSize + curSize; ++pj) {
							picture[pi][pj] = last[pi - i * curSize][pj - j * curSize];
						}
					}

				}
			}
		}
	}

	for (int i = 0; i < curSize * patSize; ++i) {
		for (int j = 0; j < curSize * patSize; ++j) {
			last[i][j] = picture[i][j];
		}
	}
}
// 数组的大小为 3000*3000 约9MB,超过了1MB的限制,所以这里设成全局变量
char pattern[3000][3000];
char last[3000][3000];
char picture[3000][3000];

int main() {
	int N;//模板的尺寸大小为 N*N
	int Q;//表示所求的图形等级

	while (1) {
		scanf("%d", &N);
		if (N == 0) {
			break;
		}
		getchar(); // fgets会读到'\n' 所以先去掉
		for (int i = 0; i < N; ++i) {
			fgets(pattern[i], 3000, stdin);
			int curLength = strlen(pattern[i]);
			for (int j = curLength - 1; j < N; ++j) {
				pattern[i][j] = ' ';
			}
		}
		scanf("%d", &Q);
		int curSize = 1;
		
		// 逐渐分形操作
		for (int i = 0; i < Q; ++i) {
			square(curSize, N, pattern, picture, last);
			curSize *= N;
		}

		for (int i = 0; i < curSize; ++i) {
			for (int j = 0; j < curSize; ++j) {
				printf("%c", picture[i][j]);
			}
			printf("\n");
		}

	}
}
相关推荐
AI科技星23 分钟前
时空的固有脉动:波动方程 ∇²L = (1/c²) ∂²L/∂t² 的第一性原理推导、诠释与验证
数据结构·人工智能·算法·机器学习·重构
阿豪只会阿巴31 分钟前
【多喝热水系列】从零开始的ROS2之旅——Day4
c++·笔记·python·ros2
2401_841495641 小时前
【LeetCode刷题】寻找重复数
数据结构·python·算法·leetcode·链表·数组·重复数
罗技1231 小时前
Easysearch 集群监控实战(下):线程池、索引、查询、段合并性能指标详解
前端·javascript·算法
一路往蓝-Anbo1 小时前
C语言从句柄到对象 (七) —— 给对象加把锁:RTOS 环境下的并发安全
java·c语言·开发语言·stm32·单片机·嵌入式硬件·算法
中國龍在廣州1 小时前
谈谈2025年人工智能现状及发展趋势分析
人工智能·深度学习·算法·自然语言处理·chatgpt·机器人·机器人学习
C雨后彩虹1 小时前
二维伞的雨滴效应
java·数据结构·算法·华为·面试
一路往蓝-Anbo1 小时前
C语言从句柄到对象 (八) —— 当对象会说话:观察者模式与事件链表
c语言·开发语言·数据结构·stm32·单片机·观察者模式·链表
郭涤生1 小时前
fmtlib/fmt仓库熟悉
c++
Stanford_11062 小时前
【2026新年启程】学习之路,探索之路,技术之路,成长之路……都与你同行!!!
前端·c++·学习·微信小程序·排序算法·微信开放平台