bzoj1800[Ahoi2009]fly 飞行棋 暴力枚举
找了道bzoj的水题,千年难得一遇。
建议初学者做做,然而我个蒟蒻初学时应该A不了.....
< http://www.lydsy.com/JudgeOnline/problem.php?id=1800 > 地址啦啦啦就来了。
进入正题,先看题目
Description
Input
Output
Sample Input
1
2
2
3
1
1
3
3
Sample Output
HINT
N<= 20

其他什么都不看,就看到 N<=20 不管说什么都是暴力吧。
在看看题目,大意: N个点在一个圆上按输入顺序依次排列,已知相邻两点距离a[i,i+1],求这些点能组成的不重复矩形个数。(大意比题目还长,主要是我语文不好)
看完这些,还要看的就是上面这个神奇的图了,看完这个就肯定是水题一道。
可以发现:是矩形的条件就是对边相等,实际上可以抽象成对边两个点在圆上的距离a[i,i+1],那么判是矩形的条件就出来了
这道题的话,效率4重到2重都可以打,我比较懒蒟,就打了个4重。
思路就差不多是这样的:(建议一边看图一边看题解)
4重枚举矩形的4个顶点,i枚举左上角的,j枚举右上角的,k枚举右下角的,k1枚举左下角的。
这时就会发现需要预处理圆上按输入顺序的所有点的距离,a[i,j]表示 i 到 j 的距离。
a[i,j]=a[i,i+1]+a[i+1,i+2]+...+a[j-1,j]; 这个为什么我应该不用说吧。
是矩形的条件:1、a[i,j]=a[k,k1](第一组对边相等);
2、a[j,k1]=? 然后就发现 i 到 k1 的边不会是那个想要的边,可以用sum先计算一下圆的周长,这条边就可以这样表示 sum-a[i,k1];
and then(措不及防的飙英语) a[j,k1]=sum-a[i,k1];(第二组对边相等);
然后就没有然后了, and then has no and then(措不及防的又飙了英语,还飙得这么不标准)
当然还有代码:
pascal:
var a:array[0..50,0..50]of longint;
n,i,j,x,k,k1:longint;
ans,sum:int64;
begin
read(n);
for i:=1 to n do
begin
read(x);
a[i,i+1]:=x; //这里是把读入数据先弄成a[i,i+1]的形式
sum:=sum+x;//sum就是圆周长
end;
for i:=1 to n do
begin
for j:=i+2 to n do// j 从 i+2 的原因是 i+1是知道的
a[i,j]:=a[i,j-1]+a[j-1,j];//预处理a[i,j],因为是按读入顺序,所以如果j<i的数据也用不到,当然也可以先预处理,看心情
end;
for i:=1 to n do//枚左上角
for j:=i+1 to n do//枚右上角
for k:=j+1 to n do//枚右下角
for k1:=k+1 to n do//枚左下角
if (a[i,j]=a[k,k1])and(a[j,k]=sum-a[i,k1]) then //判两组对边相等
begin
inc(ans); //答案加一
end;
writeln(ans);
end.
c++:
你说什么,我也不知道为什么没有c++的代码(懒得打,有时间补上)。
可能有打错的地方,可以指正哦!
c++最近才自学,可能翻译代码对我来说有点难,所以没代码不能怪我。
bzoj1800[Ahoi2009]fly 飞行棋 暴力枚举的更多相关文章
- BZOJ1800 [Ahoi2009]fly 飞行棋 【枚举】
题目 给出圆周上的若干个点,已知点与点之间的弧长,其值均为正整数,并依圆周顺序排列. 请找出这些点中有没有可以围成矩形的,并希望在最短时间内找出所有不重复矩形. 输入格式 第一行为正整数N,表示点的个 ...
- bzoj1800: [Ahoi2009]fly 飞行棋(乱搞)
1800: [Ahoi2009]fly 飞行棋 题目:传送门 题解: 大水题,早上签个到 没什么好说的...搞个前缀和,算个周长... 周长为奇数肯定误解啊废话QWQ 那么看到n<=20,还不暴 ...
- bzoj 1800: [Ahoi2009]fly 飞行棋 暴力
1800: [Ahoi2009]fly 飞行棋 Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline ...
- bzoj千题计划174:bzoj1800: [Ahoi2009]fly 飞行棋
http://www.lydsy.com/JudgeOnline/problem.php?id=1800 圆上两条直径构成矩形的对角线 #include<cstdio> using nam ...
- 【枚举】bzoj1800 [Ahoi2009]fly 飞行棋
暴力枚举. #include<cstdio> #include<algorithm> using namespace std; ],sum[],half,ans; int qu ...
- BZOJ1800 [Ahoi2009]fly 飞行棋 其他
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1800 题意概括 给出圆周上的若干个点,已知点与点之间的弧长,其值均为正整数,并依圆周顺序排列. 请 ...
- bzoj 1800: [Ahoi2009]fly 飞行棋【枚举】
在圆里所以没有平行四边形,n^4枚举点即可 #include<iostream> #include<cstdio> using namespace std; const int ...
- BZOJ1800 [Ahoi2009]fly 飞行棋
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/ ...
- BZOJ 1800: [Ahoi2009]fly 飞行棋【思维题,n^4大暴力】
1800: [Ahoi2009]fly 飞行棋 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 1689 Solved: 1335[Submit][St ...
随机推荐
- windows如何远程桌面mac
mac远程windows系统比较容易,但是windows远程mac就相对复杂一点,需要借助第三方工具来实现. 下面给出简要的远程步骤: 1.登录mac,点击苹果图标,然后单击[系统偏好设置...].如 ...
- 手机浏览器不支持 IDBObjectStore.getAll
最近在学习IndexDB,使用了IDBObjectStore.getAll,发现手机上不支持. 后面,查阅了mdn:  的确是不支持,且可以看到这个函数现在兼容性很差. 解决方法: 1.使用 IDB ...
- [转]使用Jenkins搭建持续集成(CI)环境
转自:魔のkyo的工作室 首先从官网http://jenkins-ci.org/下载 Java Web Archive (.war) 例如我保存到 D:\jenkins\jenkins.war 运行J ...
- Windows TCP连接数限制解决
reg add "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters" /v "M ...
- Solr 4.0 部署实例教程
Solr 4.0 部署实例教程 Solr 4.0的入门基础教程,先说一点部署之后肯定会有人用solrj,solr 4.0好像添加了不少东西,其中CommonsHttpSolrServer这个类改名为H ...
- iOS 10 :用 UIViewPropertyAnimator 编写动画
英文:shinobicontrols 译文:戴仓薯 链接:http://www.jianshu.com/p/4244cf130478 [iOS 10 day by day] Day 1:开发 iMes ...
- Android编码规范03
一.整个项目的目录规范化sundy老师建议有:系统目录规范.源代码目录规范. 1.系统目录规范: 指项目目录中不仅包括源代码,还需要包括:需求相关文档.设计文档.计划日志文档.测试文档.项目进行中学习 ...
- 了解HTML 元素分类
HTML中包含大量的标签, 这些标签在我们使用中发现会有小小的差别, 有的标签用了之后不会有太大的布局变化, 只是语义化, 而有的标签却会重起一行, 相当于自己回车了一次, 这就是不同标签元素的分类不 ...
- iOS 用 SDWebImage 清理图片缓存
效果图如下: 1.找到 SDWebImage找到SDImageCache类 2.添加如下方法 - (float)checkTmpSize { ; NSDirectoryEnumerator *file ...
- APP上架证书无效:解决
转发:http://www.cnblogs.com/pruple/p/5523767.html 转发:http://blog.csdn.net/sunnyboy9/article/details/50 ...