2023河南萌新联赛第(五)场:郑州轻工业大学-F 布鲁特佛斯

2023河南萌新联赛第(五)场:郑州轻工业大学-F 布鲁特佛斯

https://ac.nowcoder.com/acm/contest/62977/F

文章目录

  • 2023河南萌新联赛第(五)场:郑州轻工业大学-F 布鲁特佛斯
    • 题意
    • 解题思路
    • 代码

题意

给定一个边长为 n ( 2 ≤ n ≤ 1000 ) n(2\le n\le 1000) n(2n1000)的正方形方框,以及无数个边长为 2 ∼ 50 2\sim 50 250 的正方形拼图, 请求出恰好填满这个正方形方框的任意合法方案;若不存在构造方案,请输出 − 1 -1 1

下图是填满边长为 112 112 112的正方形边框的一种可能构造方式:
在这里插入图片描述
请注意,尽管拼图是无限的,但最终构造方案使用的正方形拼图个数应该小于 1 0 6 10^6 106

解题思路

最后一句是废话,无论怎么构造都不会超过 1 0 6 10^6 106

该题有多种构造方法,下面是出题人给的一种:
对于 n ≤ 50 n\le 50 n50则直接用一个正方形填充,对于 n n n为偶数,可以用边长为 2 2 2的小正方形填充,对于其他情况,可以按如下图:
在这里插入图片描述
对于左下角与右上角的长方形,长为 n − 9 n-9 n9,宽为 6 6 6,由于 n n n为奇数,所以 n − 9 n-9 n9也是奇数,可以直接用边长为 2 2 2的正方形填充,然后递归 n − 6 n-6 n6的长方形,仍然按上述方法填充,知道剩下边长 ≤ 50 \le 50 50时,结束。

代码

#include<bits/stdc++.h>
#define ll long long
using namespace std;
int n;
struct node{int x,y,z;
};
vector<node>a;
int x[1000]={0,1,1,4,7,7},y[1000]={0,1,7,7,1,4},z[1000]={0,6,3,3,3,3},cnt=5;
void dfs(int p,int q){if(n-p+1<=50){a.push_back(node{p,q,n-p+1});return;}for(int i=1;i<=cnt;i++)a.push_back(node{x[i]+p-1,y[i]+q-1,z[i]});for(int i=p+9;i<=n;i+=2)for(int j=q;j<q+6;j+=2)a.push_back(node{i,j,2}),a.push_back(node{j,i,2});dfs(p+6,q+6);
}
int main(){cin>>n;if(n<=50){cout<<"1\n";cout<<"1 1 "<<n;return 0;}if(n%2==0){cout<<n*n/4<<'\n';for(int i=1;i<=n;i+=2){for(int j=1;j<=n;j+=2){cout<<i<<' '<<j<<' '<<2<<'\n';}}return 0;}dfs(1,1);cout<<a.size()<<'\n';for(auto b:a){cout<<b.x<<' '<<b.y<<' '<<b.z<<'\n';}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/64088.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【wiki】电竞助手掉落提醒 EsportsHelper「Webhook」「钉钉」「饭碗警告」「企业微信」「Discord」

介绍 本项目链接 Github电竞助手链接 github上项目电竞助手(EsportsHelper)的掉落提醒配置教程,当有掉宝的时候会发送你信息提示. 至于这个脚本是怎么使用的简单说一下,就是通过自动观看英雄联盟直播 从而获取奖励(仅限直营服),有兴趣的可以去github上看readme,非常详细,支持…

Python Opencv实践 - 在图像上绘制图形

import cv2 as cv import numpy as np import matplotlib.pyplot as pltimg cv.imread("../SampleImages/pomeranian.png") print(img.shape)plt.imshow(img[:,:,::-1])#画直线 #cv.line(img,start,end,color,thickness) #参考资料&#xff1a;https://blog.csdn.ne…

摄影入门基础笔记

1.认识相机&#xff0c;传感器和镜头 微单相机和单反相机 运动相机、卡片机 微单和单反的区别&#xff1f; 微单的光学结构少了反光板的结构以及棱镜的结构 DSLR [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-PCSYr2Ob-1691407493645)(https:/…

取证--理论

资料&#xff1a; 各比赛 Writeup &#xff1a; https://meiyacup.cn/Mo_index_gci_36.html 哔站比赛复盘视频&#xff1a; https://space.bilibili.com/453117423?spm_id_from333.337.search-card.all.click 自动分析取证四部曲 新建案例添加设备自动取证制作报告 取证大…

1. 如何爬取自己的CSDN博客文章列表(获取列表)(博客列表)(手动+python代码方式)

文章目录 写在最前步骤打开chrome浏览器&#xff0c;登录网页按pagedown一直往下刷呀刷呀刷&#xff0c;直到把自己所有的博文刷出来然后我们按F12&#xff0c;点击选取元素按钮然后随便点一篇博文&#xff0c;产生如下所示代码然后往上翻&#xff0c;找到头&#xff0c;复制然…

基于R做宏基因组的进化树ClusterTree分析

写在前面 同上一篇的PCoA分析&#xff0c;这个也是基于公司结果基础上的再次分析&#xff0c;重新挑选样本&#xff0c;在公司结果提供的csv结果表上进行删减&#xff0c;本地重新分析作图 步骤 表格预处理 在公司给的ClusterTree的原始表格数据里选取要保留的样本&#xf…

使用蓝牙外设却不小心把台式机电脑蓝牙关了

起因 今天犯了一个贼SB的错误&#xff0c;起因是蓝牙键盘突然就不能输入了&#xff08;虽然是连接状态&#xff0c;但是按什么键都没有反应&#xff09; 原来我的解决方法就是重启一下电脑&#xff0c;但是那会电脑开了贼多的软件。我就想重启也太麻烦了&#xff0c;既然重启…

连锁酒店(民宿)多商户全开源版 (多店模块版),支持创建多个小程序

手边酒店多商户小程序支持创建多个小程序&#xff0c;更合适平台型或者连锁酒店使用。后台支持一键入住&#xff0c;一键退款、退押金、钟点房支持微信支付、模板消息。客服实时收到新的订单信息&#xff0c;可以在手机端处理订单。支持按日期维护房价和房间数量&#xff0c;支…

hutool 导出复杂表头excel

假如已这样的表头导出数据 1.把包含表头的excel添加到项目资源目录 2.编写代码读取表头所在sheet,并且加入需导出的数据 /*** 导出excel*/public static void downloadExcel(List<List<Object>> list, HttpServletResponse response) throws IOException {/*Strin…

Centos7源码安装redis

1、下载redis Index of /releases/ 2、解压redis tar -xvf redis-6.2.9.tar.gz 3、进入解压后的目录 cd redis-6.2.9/4、指定内存分配器为 libc make MALLOClibc 5、进入src目录&#xff0c;安装 cd src && make install6、运行 ./redis-server 7、添加开机…

三级城市展示省市区树

展示效果 数据库展示 业务代码 /*** 省市区树*/VLicenseApiOperation("查询经纬度")ApiImplicitParam(name "FnCity", value "省市区树", dataType "FnCity")GetMapping("/districtlist")public AjaxResult districtlist…

ArcGIS Pro应用—暨基础入门、制图、空间分析、影像分析、三维建模、空间统计分析与建模、python融合、案例应用全流程科研能力提升教程

详情点击链接&#xff1a;ArcGIS Pro应用—暨基础入门、制图、空间分析、影像分析、三维建模、空间统计分析与建模、python融合、案例应用全流程科研能力提升教程 第一&#xff1a;GIS及ArcGIS Pro 1.GIS基本原理及常用软件 2.ArcGIS Pro 安装与配置 3.ArcGIS Pro 3.0 的新…