- 浏览: 603940 次
- 来自: ...
文章分类
最新评论
-
lgh1992314:
相同的元素呢
一种离散化方法 -
HelloSummerR:
圆心的位置是随机的,于是圆的部分会落到canvas外,那样就显 ...
HTML5 Canvas学习笔记(1)处理鼠标事件 -
hlstudio:
好久没见到sokuban了,这有个java版的,带源码,可以参 ...
求推箱子的最小步数(java) -
肖泽文:
太好了,谢谢你。。有中文注释!
HTML5 推箱子游戏过关演示动画 -
swm8023:
删除操作,将最后一个叶子节点插入后也有可能上浮吧
彻底弄懂最大堆的四种操作(图解+程序)(JAVA)
分治化求凸包,请参看:http://128kj.iteye.com/admin/blogs/1748622
POJ 2187题意:
给出一个点集,求两点之间最长的距离的平方,最长距离的两个点一定在凸包上,
首先,将点集凸包化,这样就可以排除了很多点,接下来就是两个for就可以.
下面是AC过代码:
POJ 2187题意:
给出一个点集,求两点之间最长的距离的平方,最长距离的两个点一定在凸包上,
首先,将点集凸包化,这样就可以排除了很多点,接下来就是两个for就可以.
下面是AC过代码:
import java.util.*; class Line {//线 Point p1, p2; Line(Point p1, Point p2) { this.p1 = p1; this.p2 = p2; } public Point getP1(){ return p1; } public Point getP2(){ return p2; } public double getLength() { double dx = Math.abs(p1.x - p2.x); double dy = Math.abs(p1.y - p2.y); return Math.sqrt(dx * dx + dy * dy); } } class Point{//点 double x; double y; public Point(double x,double y){ this.x=x; this.y=y; } } /* * 分治法求凸包 */ class QuickTuBao { List<Point> pts = null;//点集 List<Line> lines = new ArrayList<Line>();//点集pts的凸包 public void setPointList(List<Point> pts) { this.pts = pts; } public QuickTuBao(List<Point> pts){ this.pts=pts; } //求凸包,结果存入lines中 public List<Line> eval() { lines.clear(); if (pts == null || pts.isEmpty()) { return lines; } List<Point> ptsLeft = new ArrayList<Point>();//左凸包中的点 List<Point> ptsRight = new ArrayList<Point>();//右凸包中的点 //按x坐标对pts排序 Collections.sort(pts, new Comparator<Point>() { public int compare(Point p1, Point p2) { if(p1.x-p2.x>0) return 1; if(p1.x-p2.x<0) return -1; return 0; } }); Point p1 = pts.get(0);//最左边的点 Point p2 = pts.get(pts.size()-1);//最右边的点,用直线p1p2将原凸包分成两个小凸包 Point p3 = null; double area = 0; for (int i = 1; i < pts.size(); i++) { p3 = pts.get(i); area = getArea(p1, p2, p3);//求此三点所成三角形的有向面积 if (area > 0) { ptsLeft.add(p3); } else if (area < 0) { ptsRight.add(p3); } } d(p1, p2, ptsLeft);//分别求解 d(p2, p1, ptsRight); return lines; } private void d(Point p1, Point p2, List<Point> s) { //s集合为空 if (s.isEmpty()) { lines.add(new Line(p1, p2)); return; } //s集合不为空,寻找Pmax double area = 0; double maxArea = 0; Point pMax = null; for (int i = 0; i < s.size(); i++) { area = getArea(p1, p2, s.get(i));//最大面积对应的点就是Pmax if (area > maxArea) { pMax = s.get(i); maxArea = area; } } //找出位于(p1, pMax)直线左边的点集s1 //找出位于(pMax, p2)直线左边的点集s2 List<Point> s1 = new ArrayList<Point>(); List<Point> s2 = new ArrayList<Point>(); Point p3 = null; for (int i = 0; i < s.size(); i++) { p3 = s.get(i); if (getArea(p1, pMax, p3) > 0) { s1.add(p3); } else if (getArea(pMax, p2, p3) > 0) { s2.add(p3); } } //递归 d(p1, pMax, s1); d(pMax, p2, s2); } // 三角形的面积等于返回值绝对值的二分之一 // 当且仅当点p3位于直线(p1, p2)左侧时,表达式的符号为正 private double getArea(Point p1, Point p2, Point p3) { return p1.x * p2.y + p3.x * p1.y + p2.x * p3.y - p3.x * p2.y - p2.x * p1.y - p1.x * p3.y; } } public class Main { //计算距离的平方 private static double dis(Point p1,Point p2){ double dx = Math.abs(p1.x - p2.x); double dy = Math.abs(p1.y - p2.y); return (dx * dx + dy * dy); } //计算最长距离的平方 private static void answer(List<Line> ls) { List<Point> l=new ArrayList<Point>();//凸包中的所有点 for (int i = 0; i < ls.size(); i++) { Line line=ls.get(i); Point p1=line.getP1(); Point p2=line.getP2(); if(!l.contains(p1)) l.add(p1); if(!l.contains(p2)) l.add(p2); } double ans=0; for (int i=0;i<l.size()-1;i++) for (int j=i+1;j<l.size();j++){ double tem=dis(l.get(i),l.get(j)); if (ans<tem) ans=tem; } System.out.printf("%.0f\n",ans); } public static void main(String[] args) { Scanner cin = new Scanner(System.in); int n = cin.nextInt(); List<Point> pts = new ArrayList<Point>(n); int x, y; for (int i = 0; i < n; i++) { x = cin.nextInt(); y = cin.nextInt(); pts.add(new Point(x, y)); } QuickTuBao qt = new QuickTuBao(pts); List<Line> ls = qt.eval(); answer(ls); } }
- Main2187.zip (1.7 KB)
- 下载次数: 2
发表评论
-
求推箱子的最小步数(java)
2014-05-06 08:32 3774题目(poj1475):推箱子,要求箱子移动步骤最小。如图:T ... -
图的深搜+回溯练习题:POJ2197
2013-01-18 15:53 1676POJ 2197题意: 给定n个城市及其之间的距离,以及距 ... -
田忌赛马: POJ 2287(贪心解法)
2013-01-03 19:24 3061POJ 2287问题描述: 你一定听过田忌赛马的故事吧? ... -
滚动数组应用:POJ 1159
2012-12-29 21:52 1485POJ 1159题意: 回文词是一种对称的字符串。任意给 ... -
POJ2092:计数排序,求第K大的元素
2012-12-27 08:31 1934题目大意: 输入N和M,N就是N次测试,M是说每次测试产生 ... -
直接插入排序练习:POJ 2388
2012-12-26 09:42 1645关于直接插入排序请参看:http://128kj.iteye. ... -
堆排序练习:POJ 2388
2012-12-26 09:27 1875关于堆排序请参看:http://128kj.iteye.com ... -
大(小)顶堆练习:POJ 1442
2012-12-24 20:58 1892POJ1442题意: ADD(a)表示向集合中增加元素a ... -
大顶堆应用:POJ2010
2012-12-23 20:59 1910POJ2010题意: 奶牛学校招生,c头奶牛报名,要选 ... -
学习凸包(五):卷包裹算法--兼解POJ1113(JAVA)
2012-12-22 13:57 1588一种形象的理解是 ... -
极角排序:POJ 1696(叉积+深搜)
2012-12-19 16:12 1769POJ1696题意: 一只很 ... -
学习凸包(四):Graham 扫描法
2012-12-17 16:33 2277Graham扫描法 基本思想:通过设置一个关于候选点的 ... -
学习凸包(三):凸包练习 POJ 1113
2012-12-16 14:50 2265接上文:学习凸包(二) ... -
学习凸包(二):分治法求解
2012-12-16 14:32 3459接上文:学习凸包(一):暴力算法求解http://128kj. ... -
学习凸包(一):暴力算法求解
2012-12-15 17:06 2117凸包:令S是平面上的一个点集,封闭S中所有顶点的最小凸多边 ... -
二维树状数组练习 POJ 2029
2012-12-13 19:53 1549关于二维树状数组请参 ... -
二维树状数组学习之二:练习POJ 1195
2012-12-12 21:40 1398接前文:二维树状数组学习之一:彻底理解http://128kj ... -
图的深搜+树状数组练习 POJ 3321(JAVA)
2012-12-11 11:13 1843关于树状数组:参看:http://128kj.iteye.co ... -
树状数组练习:POJ 3067
2012-12-09 17:10 1843关于树状数组,参看:http://128kj.iteye.co ... -
树状数组练习:POJ 2481(JAVA)
2012-12-08 18:11 1822关于树状数组,请参考:http://128kj.iteye.c ...
相关推荐
这篇博客“学习凸包(三): 凸包练习 POJ 1113”显然是关于如何通过编程解决凸包问题的一个实例。我们将深入探讨这个话题,主要关注凸包的定义、常见的求解算法以及如何用Java实现。 凸包可以被定义为一个给定集合中...
标题中的“pku_poj_2187.rar_poj 2187_凸包问题”表明这是一个关于北京大学(Peking University, PKU)编程竞赛平台POJ上的第2187题,题目主要涉及凸包问题。描述中的“O(nlogn)凸包问题 poj2187”提示我们解决这个...
ACM常用算法及其相应的练习题 本资源摘要信息涵盖了ACM常用的算法和相应的练习题,旨在帮助程序员和算法爱好者快速学习和掌握这些算法。下面详细介绍这些算法和练习题。...(4) 凸包:poj2187, poj1113
* 凸包:poj2187, poj1113 中级部分: 一、基本算法 * C++的标准模版库的应用 + poj3096, poj3007 * 较为复杂的模拟题的训练 + poj3393, poj1472, poj3371, poj1027, poj2706 二、图算法 * 差分约束系统的...
例题:poj2187、poj1113。 中级 一、基本算法 * C++的标准模版库的应用:C++的标准模版库是指C++语言的标准库,提供了许多有用的算法和数据结构。例题:poj3096、poj3007。 * 较为复杂的模拟题的训练:较为复杂的...
求解凸包问题:输入是平面上 n 个点的集合 Q,凸包问题是要输出一个 Q 的 凸包。其中,Q 的凸包是一个凸多边形 P,Q 中的点或者在 P 上或者在 P 中。 实现基于枚举方法的凸包求解算法 实现基于 Graham-Scan 的凸包...
poj题目分类 POJ(Princeton Online Judge)是一個在线编程平台...4. 凸包:例如 poj2187、poj1113。 这些知识点涵盖了算法、数据结构、数学、计算几何学等领域的多个方面,为编程爱好者和学生提供了广泛的知识基础。
4. 凸包:poj2187等题目锻炼处理凸包问题的能力。 中级阶段的学习增加了难度,涉及: 1. C++标准模板库的应用:poj3096和poj3007等题目。 2. 复杂模拟题:poj3393等题目提升复杂场景模拟能力。 3. 图算法扩展:差分...
- **凸包**:构建凸包并求解相关的几何问题。 - 示例题目:POJ 1837, POJ 1276 - **线段树与树状数组**:适用于解决区间更新与查询问题。 - 示例题目:POJ 2528, POJ 2828, POJ 2777, POJ 2886, POJ 2750 - **...
在给定的Java程序中,“计算几何求凸包算法的java实现”是解决这个问题的关键。 这个Java代码实现了对离散点集进行求解凸包的过程。在图形用户界面中,用户可以通过鼠标点击生成点,程序会实时地计算这些点的凸包并...
- **示例题目**: POJ 2187, POJ 1113 - **注意事项**: 理解凸包算法的原理和实现过程。 ### 中级算法训练 #### 一、基本算法 **1. C++标准模板库的应用** - **定义**: 使用STL提供的容器、算法和迭代器等组件...
- POJ 2976:凸包构建与性质分析。 - POJ 3150、POJ 3422:复杂几何形状的计算。 以上是对经典POJ分类的详细解析,通过这些知识点的学习,可以帮助我们更好地理解和掌握算法与数据结构的基础知识,并能够应用于...
在本文中,我们将深入探讨“学习凸包(五):卷包裹算法——兼解POJ1113(JAVA)”这一主题。凸包是计算机图形学、算法和数据结构领域中的一个重要概念,它指的是在一组点集中,由这些点构成的最小外接多边形。在解决...
最小凸包算法是一种在计算机科学中...总之,"最小凸包算法Java版"项目为学习和实践凸包算法提供了一个良好的起点。通过深入研究代码,我们可以不仅理解算法本身,还能掌握如何在实际项目中运用它,提升我们的编程技能。
java实现利用Graham算法解决凸包问题,带界面验证
在北大POJ在线判题系统中,有一道编号为1113的题目“Wall”,正是要求参赛者利用凸包算法来解决一道几何问题。 首先,要解决“Wall”问题,需要对凸包的概念有一个清晰的认识。凸包的性质在于,任何凸多边形内部的...
自己写的解决凸包问题的代码,还具备界面。
凸包程序 java版
**Melkman凸包算法详解** Melkman算法是一种在线算法,主要用于计算简单多边形的边界凸包。在计算机图形学、机器学习和数据结构领域,凸包问题是一个非常重要的概念,它可以帮助我们找到一组点中最外层的点集,这些...