题目链接:poj2284 That Nice Euler Circuit

欧拉公式:如果G是一个阶为n,边数为m且含有r个区域的连通平面图,则有恒等式:n-m+r=2。

欧拉公式的推广: 对于具有k(k≥2)个连通分支的平面图G,有:n-m+r=k+1。

题意:给出连通平面图的各顶点,求这个欧拉回路将平面分成多少区域。

题解:根据平面图的欧拉定理“n-m+r=2”来求解区域数r。

顶点个数n:两两线段求交点,每个交点都是图中的顶点。

边数m:在求交点时判断每个交点落在第几条边上,如果一个交点落在一条边上,这条边就分裂成两条边,边数加一。

学习之路漫漫啊。。

看懂了书上例题再敲的,我基础差就是累哦、、

 #include<cstdio>
#include<cmath>
#include<queue>
#include<cstring>
#include<algorithm>
using namespace std; const double eps = 1e-;
const int N = ; struct point{//点
double x, y;
point(double _x = , double _y = ): x(_x), y(_y){}
}; struct lineSegment{//线段
point s, e;
lineSegment(point s, point e): s(s), e(e){}
};
struct line{//直线
double a, b, c;
};
bool operator < (point p1, point p2){
return p1.x < p2.x || p1.x == p2.x && p1.y < p2.y;
}
bool operator == (point p1, point p2){
return abs(p1.x - p2.x) < eps && abs(p1.y - p2.y) < eps;
}
bool onLine(lineSegment l, point p){//判断点是否在线段上
return abs((l.e.x - l.s.x)*(p.y - l.s.y) - (p.x - l.s.x)*(l.e.y - l.s.y)) < eps //点在直线上
&& (p.x - l.s.x) * (p.x - l.e.x) < eps && (p.y - l.s.y) * (p.y - l.e.y) < eps;//点在线段内
}
line make_Line(point p1, point p2){//将线段延长为直线
line l;
l.a = (p2.y > p1.y) ? p2.y - p1.y : p1.y - p2.y;
l.b = (p2.y > p1.y) ? p1.x - p2.x : p2.x - p1.x;
l.c = (p2.y > p1.y) ? p1.y * p2.x - p1.x * p2.y : p1.x * p2.y - p1.y * p2.x;
return l;
}
//判断直线是否相交,并求交点p
bool line_Intersect(line l1, line l2, point &p){
double d = l1.a * l2.b - l2.a * l1.b;
if(abs(d) < eps) return false; //叉积为0,平行或重合
p.x = (l2.c * l1.b - l1.c * l2.b) /d;
p.y = (l2.a * l1.c - l1.a * l2.c) /d;
return true;
}
//判断线段是否相交
bool lineSegment_Intersect(lineSegment l1, lineSegment l2, point &p){
line a, b;
a = make_Line(l1.s, l1.e);//将线段延长为直线
b = make_Line(l2.s, l2.e);
if(line_Intersect(a, b, p))//如果直线相交
//判断直线交点是否在线段上,是则线段相交
return onLine(l1, p) && onLine(l2, p);
else return false;
} point p[N], intersection[N];
int n, m; int main(){
int nn, i, j, kase = ;
while(scanf("%d", &nn) && nn){
n = m = ;
for(i = ; i < nn; ++i)
scanf("%lf %lf", &p[i].x, &p[i].y);
for(i = ; i < nn; ++i){
for(j = ; j < nn; ++j){
if(i == j) continue;
lineSegment l1(p[i], p[(i+)%nn]), l2(p[j], p[(j+)%nn]);
point v;
if(lineSegment_Intersect(l1, l2, v))
intersection[n++] = v;//记录交点
}
}
sort(intersection , intersection + n);
//移除重复点
n = unique(intersection, intersection + n) - intersection;
for(i = ; i < n; ++i){
for(j = ; j < nn; ++j){
lineSegment l3(p[j], p[(j+)%nn]);
//若有交点落在边上,则该边分裂成两条边
if(onLine(l3, intersection[i]) && !(l3.s == intersection[i]))
m++;
}
}
printf("Case %d: There are %d pieces.\n", kase++, + m - n);
}
return ;
}

poj2284 That Nice Euler Circuit(欧拉公式)的更多相关文章

  1. POJ2284 That Nice Euler Circuit (欧拉公式)(计算几何 线段相交问题)

                                                          That Nice Euler Circuit Time Limit: 3000MS   M ...

  2. UVa 10735 (混合图的欧拉回路) Euler Circuit

    题意: 给出一个图,有的边是有向边,有的是无向边.试找出一条欧拉回路. 分析: 按照往常的思维,遇到混合图,我们一般会把无向边拆成两条方向相反的有向边. 但是在这里却行不通了,因为拆成两条有向边的话, ...

  3. UVA 10735 Euler Circuit 混合图的欧拉回路(最大流,fluery算法)

    题意:给一个图,图中有部分是向边,部分是无向边,要求判断是否存在欧拉回路,若存在,输出路径. 分析:欧拉回路的定义是,从某个点出发,每条边经过一次之后恰好回到出发点. 无向边同样只能走一次,只是不限制 ...

  4. UVA-10735 - Euler Circuit(混合欧拉回路输出)

    题意:给你一个图,有N个点,M条边,这M条边有的是单向的,有的是双向的. 问你能否找出一条欧拉回路,使得每条边都只经过一次! 分析: 下面转自别人的题解: 把该图的无向边随便定向,然后计算每个点的入度 ...

  5. Uva 1342 - That Nice Euler Circuit

    Little Joey invented a scrabble machine that he called Euler, after the great mathematician. In his ...

  6. UVALive - 3263 That Nice Euler Circuit (几何)

    UVALive - 3263 That Nice Euler Circuit (几何) ACM 题目地址:  UVALive - 3263 That Nice Euler Circuit 题意:  给 ...

  7. Euler Circuit UVA - 10735(混合图输出路径)

    就是求混合图是否存在欧拉回路 如果存在则输出一组路径 (我就说嘛 咱的代码怎么可能错.....最后的输出格式竟然w了一天 我都没发现) 解析: 对于无向边定向建边放到网络流图中add(u, v, 1) ...

  8. That Nice Euler Circuit(LA3263+几何)

    That Nice Euler Circuit Time Limit:3000MS     Memory Limit:0KB     64bit IO Format:%lld & %llu D ...

  9. UVALi 3263 That Nice Euler Circuit(几何)

    That Nice Euler Circuit [题目链接]That Nice Euler Circuit [题目类型]几何 &题解: 蓝书P260 要用欧拉定理:V+F=E+2 V是顶点数; ...

随机推荐

  1. python 列表函数

    list函数: 功能:将字符创转化为列表,例: 列表基本函数: 1.元素赋值,例: 注意:通过list[0]= 'hel',如果原来位置上有值,会覆盖掉原来的. 2.分片操作 1)显示序列,例: 注意 ...

  2. spring加载hibernate映射文件的几种方式 (转)

    在Spring的applicationContext.xml中配置映射文件,通常是在<sessionFactory>这个 Bean实例中进行的,若配置的映射文件较少时,可以用session ...

  3. 转 图片资源加密,Lua文件加密

    游戏开发中常遇到资源保护的问题. 目前游戏开发中常加密的文件类型有:图片,Lua文件,音频等文件,而其实加密也是一把双刃剑. 需要安全那就得耗费一定的资源去实现它.目前网上也有用TexturePack ...

  4. iOS - OC NSProcessInfo 系统进程信息

    前言 @interface NSProcessInfo : NSObject NSProcessInfo 类中包含一些方法,允许你设置或检索正在运行的应用程序(即进程)的各种类型的信息. 1.获取系统 ...

  5. 跨代的对决 英特尔i7-6700HQ对比i7-4720HQ性能测试

    http://itianti.sinaapp.com/index.php/cpu 跨代的对决 英特尔i7-6700HQ对比i7-4720HQ性能测试 2015-10-13 19:46:31 来源:电脑 ...

  6. Redis核心知识之—— 时延问题分析及应对、性能问题和解决方法【★★★★★】

    参考网址: Redis时延问题分析及应对:http://www.cnblogs.com/me115/p/5032177.html Redis常见的性能问题和解决方法:http://www.search ...

  7. [转载] google mock cookbook

    原文: https://code.google.com/p/googlemock/wiki/CookBook Creating Mock Classes Mocking Private or Prot ...

  8. iOS开发之 XCode6.0的iOS免证书真机测试方法(MAC及黑苹果均有效)

    参考:http://mobile.51cto.com/iphone-455500.htm XCode6.0的iOS免证书真机测试方法(MAC及黑苹果均有效) 前提:设备已经越狱 目前在XCode上开发 ...

  9. hdu 4414 Finding crosses

    题目链接:hdu 4414 其实是一道简单的字符型水题,不涉及任何算法,可比赛时却没能做出来,这几天的状态都差到家了... 题目大意是求有多少个满足条件的十字架,十字架的边不能有分叉路口,所以枚举每个 ...

  10. D3.js 弦图的制作

    这是一种用于描述节点之间联系的图表. 1. 弦图是什么 弦图(Chord),主要用于表示两个节点之间的联系. 两点之间的连线,表示谁和谁具有联系: 线的粗细表示权重: 2. 数据 初始数据为: var ...