POJ-2318 TOYS,暴力+叉积判断!
2页的提交记录终于搞明白了。
题意:一个盒子由n块挡板分成n+1块区域,有m个玩具,每次给出一个玩具的坐标,最后输出各个区域玩具的数量,玩具不会在线上或者盒子外面,挡板也不会相交。输出格式请看样例!
思路:考察叉积的性质,用一个结构体存线段(两个点共4个坐标),然后输入一个玩具坐标就遍历所有的区域找到然后对应区域加1。
这题看起来也不难,数据5000,开始想着用二分即可,但区域形状不规则,二分可能没有确定的区域,会有极端的例子如挡板全部是平行的斜线,倾斜度越高越不好找,于是放弃了这种思路,后来想着既然输入的区域顺序是确定的,那么对玩具坐标进行排序,每次只需从前面找的那个区域往后找即可。于是开启了无限WA模式,后来改成两层循环秒A。。。又重复用前面那种思路反复测试发现后台数据最大只有42个,两层循环随便水只要思路没错。
先来一个WA的代码:
struct line
{
double x1,y1,x2,y2;
} a[N],b[N];
int v[N];
int cmp(line a,line b)
{
return a.x1<b.x1;
}
double multi(line b,line a)
{
return (a.x1-b.x1)*(a.y2-b.y1)-(a.x2-b.x1)*(a.y1-b.y1);
}
int main()
{
int n,m;
double x1,y1,x2,y2;
while(~scanf("%d",&n)&&n)
{
scanf("%d%lf%lf%lf%lf",&m,&x1,&y1,&x2,&y2);
memset(v,0,sizeof(v));
for(int i=1; i<=n; i++) //n条分界分成n+1个区域
{
scanf("%lf%lf",&a[i].x1,&a[i].x2);
a[i].y1=y1;
a[i].y2=y2;
}
a[0].x1=x1,a[0].y1=y1,a[0].x2=x1,a[0].y2=y2;//开始隔板
a[n+1].x1=x2,a[n+1].y1=y1,a[n+1].x2=x2,a[n+1].y2=y2;//最后一块区域
for(int i=0; i<m; i++) scanf("%lf%lf",&b[i].x1,&b[i].y1);
sort(b,b+m,cmp);
int j=0;
for(int i=0; i<m; i++)
{
while(multi(b[i],a[j])>0&&j<=n+1) j++;//接着前一个区域往后找直到满足条件。
j--;
v[j]++;
//j-=41;//就是这里测出了后台。
//if(j<0) j=0;
}
for(int i=0; i<=n; i++)
printf("%d: %d\n",i,v[i]);
printf("\n");
}
return 0;
}
以上思路看似很正确,但还是有退化的例子,比如:
2 2 0 100 100 0
1 50
8 70
25 99
40 1
应该输出:
0: 1
1: 1
2: 0
而运行结果:
0: 0
1: 1
2: 1
正确代码:
struct line
{
double x1,y1,x2,y2;
} a[N];
int v[N];
double multi(double x,double y,line a)
{
return (a.x1-x)*(a.y2-y)-(a.x2-x)*(a.y1-y);
}
int main()
{
int n,m;
double x1,y1,x2,y2;
while(~scanf("%d",&n)&&n)
{
scanf("%d%lf%lf%lf%lf",&m,&x1,&y1,&x2,&y2);
memset(v,0,sizeof(v));
for(int i=1; i<=n; i++) //n条分界分成n+1个区域
{
scanf("%lf%lf",&a[i].x1,&a[i].x2);
a[i].y1=y1,a[i].y2=y2;
}
a[0].x1=x1,a[0].y1=y1,a[0].x2=x1,a[0].y2=y2;//开始隔板
a[n+1].x1=x2,a[n+1].y1=y1,a[n+1].x2=x2,a[n+1].y2=y2;//最后一块区域
double x,y;
for(int i=0; i<m; i++)
{
int j=0;
scanf("%lf%lf",&x,&y);
while(multi(x,y,a[j])>0) j++;
v[j-1]++;
}
for(int i=0; i<=n; i++)
printf("%d: %d\n",i,v[i]);
printf("\n");
}
return 0;
}
POJ-2318 TOYS,暴力+叉积判断!的更多相关文章
- POJ 2318 TOYS 利用叉积判断点在线段的那一侧
题意:给定n(<=5000)条线段,把一个矩阵分成了n+1分了,有m个玩具,放在为位置是(x,y).现在要问第几个位置上有多少个玩具. 思路:叉积,线段p1p2,记玩具为p0,那么如果(p1p2 ...
- POJ 2318 TOYS(叉积+二分)
题目传送门:POJ 2318 TOYS Description Calculate the number of toys that land in each bin of a partitioned ...
- poj 2318 TOYS (二分+叉积)
http://poj.org/problem?id=2318 TOYS Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 101 ...
- POJ 2318 TOYS【叉积+二分】
今天开始学习计算几何,百度了两篇文章,与君共勉! 计算几何入门题推荐 计算几何基础知识 题意:有一个盒子,被n块木板分成n+1个区域,每个木板从左到右出现,并且不交叉. 有m个玩具(可以看成点)放在这 ...
- POJ 2318 TOYS (叉乘判断)
<题目链接> 题目大意: 给出矩形4个点和n个挡板俩顶点的位置,这n个挡板将该矩形分成 n+1块区域,再给你m个点的坐标,然你输出每个区域内有几个点. 解题思路: 用叉乘即可简单判断点与直 ...
- 向量的叉积 POJ 2318 TOYS & POJ 2398 Toy Storage
POJ 2318: 题目大意:给定一个盒子的左上角和右下角坐标,然后给n条线,可以将盒子分成n+1个部分,再给m个点,问每个区域内有多少各点 这个题用到关键的一步就是向量的叉积,假设一个点m在 由ab ...
- POJ 2318 TOYS (叉积+二分)
题目: Description Calculate the number of toys that land in each bin of a partitioned toy box. Mom and ...
- poj 2318 TOYS & poj 2398 Toy Storage (叉积)
链接:poj 2318 题意:有一个矩形盒子,盒子里有一些木块线段.而且这些线段坐标是依照顺序给出的. 有n条线段,把盒子分层了n+1个区域,然后有m个玩具.这m个玩具的坐标是已知的,问最后每一个区域 ...
- POJ 2318 TOYS 叉积
题目大意:给出一个长方形盒子的左上点,右下点坐标.给出n个隔板的坐标,和m个玩具的坐标,求每个区间内有多少个玩具. 题目思路:利用叉积判断玩具在隔板的左方或右方,并用二分优化查找过程. #includ ...
随机推荐
- I/O————数据流
如何将一个long类型的数据写入文件中? 转字符串 → 通过 getbytes() 写进去,费劲,而且在此过程中 long 类型的数需要不断地转换. 现在,Java 中的数据流能够很好的解决这个问题( ...
- jsp实现账户登录、注册!
jsp连接mysql数据库进行账户登录验证和账户注册 ~jsp: Login.jsp .LoginCl.jsp.Welcome.jsp.Register.jsp.login.css login.css ...
- 详解HTML中的表格标签
详细代码如下: <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" ...
- 利用自定义消息处理函数的WPARAM或LPARAM参数传递指针
有自定义消息: #define WM_TEST WM_USER+121 消息处理函数: afx_msg void OnTest(WPARAM wParam,LPARAM lParam); 该消息是一个 ...
- Android 实现类似于QQ空间相册的点击图片放大,再点后缩小回原来位置
前几天看到了有人在android5.0上实现了如下图一样的效果,我自己就去搜了下.参考了国外一篇文章和国内的一篇文章,最终实现了想要的效果.具体参考的网址我已经贴到文章末尾,大家可以去英文的那个网站看 ...
- [翻译] API测试的最佳实践 - 介绍
API测试的最佳实践 - 介绍 在上一篇“是什么让API测试很叼”一文中,我们讨论API与其他形式的软件测试的差异.部分是因为API之间的通信压根就没考虑让你能读懂,纯粹是为了方便计算机之间的交互而设 ...
- 重置Mysql的root密码及用户权限设置
一.重置Mysql的root密码 方法一: 直接进入localhost/phpmyadmin修改用户root的权限,设置密码: 方法二: 进入mysql控制台:mysql->use mysql ...
- 后台安装 SQL Server 无人值守 安装
(开头闲淡)项目需要必须安装SQL的,查了很久,断断续续用了各种方法,今天终于用了正确的姿(xia)势(mo)弄成了. 最开始用的方法是调用Win的API模拟鼠标操作安装的,嗯,虽然勉强可以,就是有些 ...
- 如何修改tomcat的启动方式为 run
tomcat根目录\bin\startup.bat,记事本打开,找到: call "%EXECUTABLE%" start %CMD_LINE_ARGS% :end 把start ...
- SQL Server2005的数据还原与备份具体步骤
一:备份数据库步骤 1. 第一步:在开始—>程序(P)—>MicrosoftSQLserver2005—>SQLServerManagementStudio(如下图) 2. 第二步: ...