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 ...
随机推荐
- 各大互联网公司前端面试题(HTML/CSS)
Html篇: 1.你做的页面在哪些流览器测试过?这些浏览器的内核分别是什么? IE: trident内核 Firefox:gecko内核 Safari:webkit内核 Opera:以前是presto ...
- iOS-私有API与runtime
转载:http://www.jianshu.com/p/6167b9ce7af8 序 有朋友在做类似iTool的功能,跟我聊起来,这几天闲,就写了一个demo,不是正经做这个,还很粗略,具体干货诸位等 ...
- 利用CSS3实现图片无间断轮播图的实现思路
前言:图片轮播效果现在在各大网站都是非常普遍的,以前我们都是通过postion的left or right来控制dom的移动,这里我要说的是利用css3来制作轮播!相比以前通过postion来移动do ...
- iOS 应用评分
为了提高应用的用户体验,经常需要邀请用户对应用进行评分 应用评分无非就是跳转到AppStore展示自己的应用,然后由用户自己撰写评论 如何跳转到AppStore,并且展示自己的应用 方法1 NSStr ...
- 联想A880 DIY 换触摸屏屏幕
今年初入手的Lenovo A880手机,由于摔坏了屏幕不过能正常显示,咨询了联想的售后,说触摸屏和显示屏是分离的,换触摸屏需要280左右 为发挥DIY的精神,准备自己来处理这个屏幕 第一步:购买屏幕, ...
- Android—基于Socket与上传图片到客户端
最近项目中需要客户端和Socket互相传递数据时候需要相互传递图片所以做下总结以免以后忘记,也希望给大家带来帮助. 先上客户端的代码: 根据图片名称上传照相机中单个照片(此方法为自己封装) 参数所代表 ...
- MySQL单表百万数据记录分页性能优化
背景: 自己的一个网站,由于单表的数据记录高达了一百万条,造成数据访问很慢,Google分析的后台经常报告超时,尤其是页码大的页面更是慢的不行. 测试环境: 先让我们熟悉下基本的sql语句,来查看下我 ...
- SQLiteOpenHelper类
SQLiteOpenHelper是管理数据库的工具类. 下面提供一个模板: package com.example.intelligencecontrol.utils; import android. ...
- IOS Emoji表情
IOS Emoji 前言:我比较喜欢有趣的东西,有一些有趣的小东西,可能不是多么多么牛逼,也可能不需要多高深的技巧,也不会为其他什么强大的功能而服务,但是有时候将很多有趣的小东西组合起来运用,比如在你 ...
- [翻译] 聚集索引表 VS 堆表
前言: 本文对这篇博客Clustered Tables vs Heap Tables 的翻译, 如有翻译不对或不好的地方,敬请指出,大家一起学习进步. 问题描述 创建一个新表时,一个非常重要的设计原则 ...