当前位置: 首页 > news >正文

在线网站开发指数函数图像及性质

在线网站开发,指数函数图像及性质,阜新小程序 阜新网站建设开发,网站成本登录—专业IT笔试面试备考平台_牛客网 题目大意:有n*n个边长为1的小正方形摆放在边长为n的大正方形中,每次可以选择不超过50个正方形,将其合并为一个更大的正方形,求一种可行的操作使所有小正方形都被合并成一个n*n的大正方形 1…

登录—专业IT笔试面试备考平台_牛客网

题目大意:有n*n个边长为1的小正方形摆放在边长为n的大正方形中,每次可以选择不超过50个正方形,将其合并为一个更大的正方形,求一种可行的操作使所有小正方形都被合并成一个n*n的大正方形

1<=n<=1000

思路:对于一个a*b(a>b)的矩形,我们可以用类似黄金分割的办法将其分割成cnt个b*b的正方形,然后剩下一个(a-cnt)*b*b的矩形,继续分割,一定能最后分割到剩下的矩形边长为1的情况,所以我们将一开始的大正方形分割成左上、右下两个边长分别为a,b的正方形,和剩下两个a*b的矩形,就可以完成题目要求。

现在来求a,b,我们可以从1到n枚举分割出来的矩形边长a,b=n-a,然后用辗转相减法,求出最后剩下边长为1的矩形是,一共构造出了几个正方形,如果<=24,那么两个矩形加起来加上a*a,b*b的正方形就不会超过50个

打表求出每个正方形的边长对应的a,b之后,我们就可以递归求解,每次从大正方形开始,先记录答案,然后分别递归到四个分出来的图形中,横着的和竖着的也就是一开始左下和右上的矩形要分别写一个递归,最后将所有答案逆序输出即可

//#include<__msvc_all_public_headers.hpp>
#include<bits/stdc++.h>
using namespace std;
const int N = 1005;
typedef long long ll;
const ll MOD=998244353;
int siz[N];
vector<pair<int, pair<int, int>>>ans;
bool check(int a, int b)
{//辗转相减法计算a*b的矩形能分割出几个正方形if (!b)return a <= 7;//7*7以下的可以直接合并成一个int cnt = 1;while (b){cnt += a / b;int c = a % b;a = b;b = c;}return cnt <= 25;//将初始的大正方形分割成了两个矩形
}
void dfs2(int x, int y, int leny, int lenx);
void dfs3(int x, int y, int leny, int lenx);
void dfs(int x, int y, int s)
{//当前正方形的坐标,大小if (s == 1)return;//边长为1的不用记录ans.push_back({ x,{y,s} });if (!siz[s])return;//分不了的就和别人一起合并即可int a = s - siz[s], b = siz[s];dfs2(x + a, y, b, a);//左下角的矩形dfs3(x, y + a, a, b);//右上角的矩形dfs(x, y, a);//左上角的正方形dfs(x + a, y + a, b);//右下角的正方形
}
void dfs2(int x, int y, int lenx, int leny)
{//矩形坐标,纵轴长,横轴长if (lenx <= 1)return;int cnt = leny / lenx;//当前矩形能分出几个正方形for (int i = 0; i < cnt; i++){dfs(x, y + i * lenx, lenx);//继续分割切出来的每个小正方形}dfs3(x, y + cnt * lenx, lenx, leny % lenx);//剩下的矩形变成了竖着的
}
void dfs3(int x, int y, int lenx, int leny)
{//横着的矩形if (leny <= 1)return;int cnt = lenx / leny;for (int i = 0; i < cnt; i++){dfs(x + i * leny, y, leny);}dfs2(x + cnt * leny, y, lenx % leny, leny);
}
int main()
{int n;cin >> n;for (int i = 1; i <= n; i++){for (int j = 0; j <= i / 2; j++){//检查n以内所有分割方案是否合法if (check(i - j, j)){siz[i] = j;break;}}}dfs(1, 1, n);cout << ans.size() << endl;reverse(ans.begin(), ans.end());//获取的答案是从大到小,要求是从小到大for (int i = 0; i < ans.size(); i++){cout << ans[i].first << " " << ans[i].second.first << " " << ans[i].second.second << endl;}return 0;
}

http://www.hkea.cn/news/522530/

相关文章:

  • 高端网站建设公司好不好2020国内搜索引擎排行榜
  • 网站建设服务公司选哪家比较好?苏州优化收费
  • 中国建设银行河南省分行网站推广信息哪个平台好
  • 网站建设官网免费模板杭州seo优化
  • 绍兴网站建设谷歌搜索引擎在线
  • 网站的会员认证怎么做黑龙江新闻头条最新消息
  • 做网站如何分工百度推广登录平台客服
  • 网站建设如何提案万网域名注册信息查询
  • 创意二维码制作网站企业网络营销推广案例
  • 论坛型网站怎么做百度高级检索入口
  • 做百度移动网站排搜素引擎优化
  • 公司创建一个网站需要多少钱想做百度推广找谁
  • 做文献ppt模板下载网站有哪些常德政府网站
  • 青岛网站建设公司排行外链工具在线
  • 网站怎么做显得简洁美观seo数据是什么意思
  • 阿里巴巴开通诚信通后网站怎么做网络优化网站
  • 东莞手机网站价格便宜个人免费建站软件
  • 电子商务网站建设的步骤一般为百度100%秒收录
  • 做企业网站怎么样免费的推广软件下载
  • 拓普网站建设美国搜索引擎
  • 网站开发者工资冯耀宗seo视频教程
  • 软件开发各阶段工作量比例搜索引擎优化的基础是什么
  • 网站怎么做才能将名声打响云搜索app
  • 南阳做网站优化哪家好一级域名生成二级域名
  • 3322动态域名官网郑州seo联系搜点网络效果好
  • 网络营销渠道的类型河北seo基础教程
  • 做微信网站多少钱seo内部优化包括哪些内容
  • 中国城乡建设网站网络优化公司排名
  • 个人网站做淘宝客教程torrentkitty磁力搜索引擎
  • 广州北京网站建设seo培训讲师招聘