2024年广东省大学生程序设计竞赛暨广东省邀请赛-个人线上赛 D. 马(构造)

本文主要是介绍2024年广东省大学生程序设计竞赛暨广东省邀请赛-个人线上赛 D. 马(构造),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目

题目详情 - 马 - HydroOJ

中国象棋规则,n*m的地图放k个马,使得任意两个马互相不能攻击

思路来源

乱搞ac

题解

三个三角形数之和一定能表示所有数(打表发现的)

输出一个矩形抠掉三个等腰直角三角形即可

原题的spj好像有点问题,自己搬了一下造了个交洛谷过了

代码

//#include<bits/stdc++.h>
#include<iostream>
#include<cstdio>
#include<vector>
#include<map>
#include<queue>
using namespace std;
#define rep(i,a,b) for(int i=(a);i<=(b);++i)
#define per(i,a,b) for(int i=(a);i>=(b);--i)
typedef long long ll;
typedef double db;
typedef pair<int,int> P;
#define fi first
#define se second
#define pb push_back
#define dbg(x) cerr<<(#x)<<":"<<x<<" ";
#define dbg2(x) cerr<<(#x)<<":"<<x<<endl;
#define SZ(a) (int)(a.size())
#define sci(a) scanf("%d",&(a))
#define pt(a) printf("%d",a);
#define pte(a) printf("%d\n",a)
#define ptlle(a) printf("%lld\n",a)
#define debug(...) fprintf(stderr, __VA_ARGS__)
using namespace std;
const int N=1e3+10,M=3e6+10;
int t,n,m,k,z[N];
array<int,3>now[M];
bool vis[M],swp;
vector<P>ans;
void init(){rep(i,0,1000)z[i]=i*(i+1)/2;rep(i,0,1000){rep(j,0,i){now[z[i]+z[j]]={i,j,0};vis[z[i]+z[j]]=1;}}rep(i,1,1000000){if(!vis[i]){for(int j=0;;j++){int v=z[j];if(i>=v && vis[i-v]){now[i]={now[i-v][0],now[i-v][1],j};break;}}}}
}
void check(){vector<vector<bool>>got(n+1,vector<bool>(m+1,0));for(auto &x:ans){got[x.fi][x.se]=true;}static int dx[]={1,1,-1,-1,2,2,-2,-2};static int dy[]={2,-2,2,-2,1,-1,1,-1};int cnt=0;for(int i=1;i<=n;i++) {for(int j=1;j<=m;j++) {if(!got[i][j]) continue;cnt++;for(int d=0;d<8;d++) {int x=i+dx[d],y=j+dy[d];if(x<1||x>n||y<1||y>m||!got[x][y]) continue;int nx=i+dx[d]/2,ny=j+dy[d]/2;if(1<=nx&&nx<=n&&1<=ny&&ny<=m&&got[nx][ny]) continue;if(got[x][y])assert(false);}}}if(cnt!=k)assert(false);
}
void out(){puts("YES");assert(SZ(ans)==k);check();for(auto &x:ans){if(swp)swap(x.fi,x.se);}sort(ans.begin(),ans.end());for(auto &x:ans){printf("%d %d\n",x.fi,x.se);}ans.clear();swp=0;
}
bool sol(){if(n>m)swap(n,m),swp=1;if(n<=2){rep(j,1,m){rep(i,1,n){if(SZ(ans)<k)ans.pb(P(i,j));else return 1;}}return 1;}rep(x,1,n){rep(y,x,m){int del=x*y-k;if(del<0)continue;int x1=now[del][0],x2=now[del][1],x3=now[del][2];assert(x1*(x1+1)/2 + x2*(x2+1)/2 + x3*(x3+1)/2 == del);if(x1<=x && x2<=x-(x==y) && x3<=min(y-x1,x-x2)){rep(i,1,x){rep(j,1,y){if(i+j<=1+x1)continue;if(i+j>=x+y-x2+1)continue;if(j-i>=y-x3)continue;ans.pb(P(i,j));}}return 1;}}}assert(false);return 0;
}
int main(){init();sci(t);while(t--){sci(n),sci(m),sci(k);sol();out();}return 0;
}

这篇关于2024年广东省大学生程序设计竞赛暨广东省邀请赛-个人线上赛 D. 马(构造)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1027301

相关文章

2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题

题库来源:安全生产模拟考试一点通公众号小程序 2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题是由安全生产模拟考试一点通提供,流动式起重机司机证模拟考试题库是根据流动式起重机司机最新版教材,流动式起重机司机大纲整理而成(含2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题参考答案和部分工种参考解析),掌握本资料和学校方法,考试容易。流动式起重机司机考试技

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

高效录音转文字:2024年四大工具精选!

在快节奏的工作生活中,能够快速将录音转换成文字是一项非常实用的能力。特别是在需要记录会议纪要、讲座内容或者是采访素材的时候,一款优秀的在线录音转文字工具能派上大用场。以下推荐几个好用的录音转文字工具! 365在线转文字 直达链接:https://www.pdf365.cn/ 365在线转文字是一款提供在线录音转文字服务的工具,它以其高效、便捷的特点受到用户的青睐。用户无需下载安装任何软件,只

2024网安周今日开幕,亚信安全亮相30城

2024年国家网络安全宣传周今天在广州拉开帷幕。今年网安周继续以“网络安全为人民,网络安全靠人民”为主题。2024年国家网络安全宣传周涵盖了1场开幕式、1场高峰论坛、5个重要活动、15场分论坛/座谈会/闭门会、6个主题日活动和网络安全“六进”活动。亚信安全出席2024年国家网络安全宣传周开幕式和主论坛,并将通过线下宣讲、创意科普、成果展示等多种形式,让广大民众看得懂、记得住安全知识,同时还

2024/9/8 c++ smart

1.通过自己编写的class来实现unique_ptr指针的功能 #include <iostream> using namespace std; template<class T> class unique_ptr { public:         //无参构造函数         unique_ptr();         //有参构造函数         unique_ptr(

论文翻译:arxiv-2024 Benchmark Data Contamination of Large Language Models: A Survey

Benchmark Data Contamination of Large Language Models: A Survey https://arxiv.org/abs/2406.04244 大规模语言模型的基准数据污染:一项综述 文章目录 大规模语言模型的基准数据污染:一项综述摘要1 引言 摘要 大规模语言模型(LLMs),如GPT-4、Claude-3和Gemini的快

免费也能高质量!2024年免费录屏软件深度对比评测

我公司因为客户覆盖面广的原因经常会开远程会议,有时候说的内容比较广需要引用多份的数据,我记录起来有一定难度,所以一般都用录屏工具来记录会议内容。这次我们来一起探索有什么免费录屏工具可以提高我们的工作效率吧。 1.福晰录屏大师 链接直达:https://www.foxitsoftware.cn/REC/  录屏软件录屏功能就是本职,这款录屏工具在录屏模式上提供了多种选项,可以选择屏幕录制、窗口

leetcode105 从前序与中序遍历序列构造二叉树

根据一棵树的前序遍历与中序遍历构造二叉树。 注意: 你可以假设树中没有重复的元素。 例如,给出 前序遍历 preorder = [3,9,20,15,7]中序遍历 inorder = [9,3,15,20,7] 返回如下的二叉树: 3/ \9 20/ \15 7   class Solution {public TreeNode buildTree(int[] pr

HomeBank:开源免费的个人财务管理软件

在个人财务管理领域,找到一个既免费又开源的解决方案并非易事。HomeBank&nbsp;正是这样一个项目,它不仅提供了强大的功能,还拥有一个活跃的社区,不断推动其发展和完善。 开源免费:HomeBank 是一个完全开源的项目,用户可以自由地使用、修改和分发。用户友好的界面:提供直观的图形用户界面,使得非技术用户也能轻松上手。数据导入支持:支持从 Quicken、Microsoft Money

每日一题|牛客竞赛|四舍五入|字符串+贪心+模拟

每日一题|四舍五入 四舍五入 心有猛虎,细嗅蔷薇。你好朋友,这里是锅巴的C\C++学习笔记,常言道,不积跬步无以至千里,希望有朝一日我们积累的滴水可以击穿顽石。 四舍五入 题目: 牛牛发明了一种新的四舍五入应用于整数,对个位四舍五入,规则如下 12345->12350 12399->12400 输入描述: 输入一个整数n(0<=n<=109 ) 输出描述: 输出一个整数