poj1279

板子题,求多边形内核面积。

话说jls的板子返回的是边,然后我就在冥思苦想怎么根据割边求面积啊。。

然后发现自己果然是个傻逼,求一下交点存起来就好了。。。

//板子题到此为止了

  1 #include <iostream>
  2 #include <cstdio>
  3 #include <algorithm>
  4 #include <vector>
  5 #include <cmath>
  6 #include <deque>
  7 
  8 using namespace std;
  9 typedef double db;
 10 const db eps=1e-6;
 11 const db pi=acos(-1);
 12 int sign(db k){
 13     if (k>eps) return 1; else if (k<-eps) return -1; return 0;
 14 }
 15 int cmp(db k1,db k2){return sign(k1-k2);}
 16 struct point{
 17     db x,y;
 18     point operator + (const point &k1) const{return (point){k1.x+x,k1.y+y};}
 19     point operator - (const point &k1) const{return (point){x-k1.x,y-k1.y};}
 20     point operator * (db k1) const{return (point){x*k1,y*k1};}
 21     point operator / (db k1) const{return (point){x/k1,y/k1};}
 22     db getP()const { return sign(y)==1||(sign(y)==0&&sign(x)==-1);}
 23 };
 24 db cross(point k1,point k2){ return k1.x*k2.y-k1.y*k2.x;}
 25 db dot(point k1,point k2){ return k1.x*k2.x+k1.y*k2.y;}
 26 db rad(point k1,point k2){ return atan2(cross(k1,k2),dot(k1,k2));}
 27 int compareangle(point k1,point k2){
 28     return k1.getP()<k2.getP()||(k1.getP()==k2.getP()&&sign(cross(k1,k2))>0);
 29 }
 30 point getLL(point k1,point k2,point k3,point k4){
 31     db w1=cross(k1-k3,k4-k3),w2=cross(k4-k3,k2-k3);
 32     return (k1*w2+k2*w1)/(w1+w2);
 33 }
 34 struct line{
 35     point p[2];
 36     line(point k1,point k2){p[0]=k1;p[1]=k2;}
 37     point &operator[](int k){ return p[k];}
 38     int include(point k){ return sign(cross(p[1]-p[0],k-p[0])>0);}
 39     point dir(){ return p[1]-p[0];}
 40 };
 41 point getLL(line k1,line k2){
 42     return getLL(k1[0],k1[1],k2[0],k2[1]);
 43 }
 44 int parallel(line k1,line k2){ return sign(cross(k1.dir(),k2.dir()))==0;}
 45 int sameDir(line k1,line k2){
 46     return parallel(k1,k2)&&sign(dot(k1.dir(),k2.dir()))==1;
 47 }
 48 int operator <(line k1,line k2){
 49     if(sameDir(k1,k2))return k2.include(k1[0]);
 50     return compareangle(k1.dir(),k2.dir());
 51 }
 52 int checkpos(line k1,line k2,line k3){ return k3.include(getLL(k1,k2));}
 53 vector<line> getHL(vector<line> &L){
 54     sort(L.begin(),L.end());deque<line> q;
 55     for(int i=0;i<L.size();i++){
 56         if(i&&sameDir(L[i],L[i-1]))continue;
 57         while (q.size()>1&&!checkpos(q[q.size()-2],q[q.size()-1],L[i]))q.pop_back();
 58         while (q.size()>1&&!checkpos(q[1],q[0],L[i]))q.pop_front();
 59         q.push_back(L[i]);
 60     }
 61     while (q.size()>2&&!checkpos(q[q.size()-2],q[q.size()-1],q[0]))q.pop_back();
 62     while (q.size()>2&&!checkpos(q[1],q[0],q[q.size()-1]))q.pop_front();
 63     vector<line> ans;for(int i=0;i<q.size();i++)ans.push_back(q[i]);
 64     return ans;
 65 }
 66 int t,n;
 67 point p[1551];
 68 bool cw(){//时针
 69     db s=0;
 70     for(int i=1;i<n-1;i++){
 71         s+=cross(p[i]-p[0],p[i+1]-p[0]);
 72     }
 73     return s>0;
 74 }
 75 vector<line>l;
 76 int main(){
 77     scanf("%d",&t);
 78     while (t--){
 79         scanf("%d",&n);
 80         for(int i=0;i<n;i++){
 81             scanf("%lf%lf",&p[i].x,&p[i].y);
 82         }
 83         if(!cw())reverse(p,p+n);
 84         for(int i=0;i<n;i++){
 85             l.push_back(line(p[i],p[(i+1)%n]));
 86         }
 87         l=getHL(l);
 88         if(l.size()<3){
 89             printf("0.00\n");
 90         } else{
 91             vector<point> a;
 92             for(int i=0;i<l.size();i++){
 93                 a.push_back(getLL(l[i],l[(i+1)%l.size()]));
 94             }
 95             db ans = 0;
 96             for(int i=1;i<a.size()-1;i++)
 97                 ans+=cross(a[i]-a[0],a[i+1]-a[0]);
 98             ans/=2;
 99             printf("%.2f\n",ans);
100         }
101         l.clear();
102     }
103 }
View Code

 

转载于:https://www.cnblogs.com/MXang/p/10453657.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/569720.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

回溯法在解决八皇后问题中的应用

回溯法&#xff1a;有这样一类题目&#xff0c;它们要求在相对问题的输入规模按照指数速度增长&#xff08;或者更快&#xff09;的域中&#xff0c;找出一个具有指定特性的元素。例如&#xff1a;在图顶点的所有排列中求一个哈密顿回路&#xff0c;在背包问题的一个实例中求其…

python数据结构与算法之问题求解

懂得计算机的童鞋应该都知道&#xff0c;一条计算机程序由数据结构跟算法两大部分组成。所以&#xff0c;其实不管你使用哪种计算机语言编写程序&#xff0c;最终这两部分才是一个程序设计的核心。所以&#xff0c;一个不懂得数据结构与算法的程序员不是一个好工程师。因此&…

运用tp5上传图片,并生成缩略图

最近想做个相册&#xff0c;需要用到上传图像&#xff0c;并且考虑到性能问题&#xff0c;还要生成缩略图&#xff0c;就学习下。在网上看了很多大神写的文章&#xff0c;经过各种调试总算出来了&#xff0c;分享下。不好之处&#xff0c;多多指教 ​ ​ ps&#xff1a;运用tp5…

求解最长回文子串----Manacher 算法

最长回文子串问题&#xff1a;给定一个字符串&#xff0c;求它的最长回文子串长度。 如果一个字符串正着读和反着读是一样的&#xff0c;那么我们称之为回文串。例如&#xff1a;abba、aaaa、abvcba、123321等 暴力法&#xff1a;遍历字符串的所有子串&#xff0c;对每个字串进…

Peter's smokes -poj 2509

题意&#xff1a;彼得有n支雪茄&#xff0c;每k个烟头可以换一支新雪茄&#xff0c;问彼得最多可以吸多少支雪茄 &#xff1f; 当时自己做时&#xff0c;错在了直接在while循环开始前&#xff0c;便将雪茄的初始数量给加上了&#xff0c;然而应该是先处理后再加上最终剩余的雪茄…

模式匹配算法----KMP算法以及next数组的解法

KMP算法&#xff1a;求字符串匹配&#xff08;也叫模式匹配&#xff09;的算法&#xff0c;即给定一个字符串&#xff0c;求其某一子串在其中出现的位置。 普通模式匹配 例如&#xff1a;给定字符串为abcabaaabaabcac&#xff0c;求其子串abaabcac在其中出现的位置。 结果为…

Spring Boot使用layui的字体图标时无法正常显示 解决办法

在html文件使用字体图标并且预览时正常&#xff0c;但是启动工程后显示不正常&#xff0c;浏览器调试界面显示字体文件无法decode&#xff1a; Failed to decode downloaded font: xxxxx 如图所示&#xff1a; 显示结果&#xff1a; 原因&#xff1a;经过maven的filter&#xf…

蓝桥杯第七届国赛JAVA真题----机器人塔

机器人塔X星球的机器人表演拉拉队有两种服装&#xff0c;A和B。 他们这次表演的是搭机器人塔。 类似&#xff1a;队内的组塔规则是&#xff1a; A 只能站在 AA 或 BB 的肩上。B 只能站在 AB 或 BA 的肩上。你的任务是帮助拉拉队计算一下&#xff0c;在给定A与B的人数时&…

Python divmod() 函数

Python divmod() 函数 Python 内置函数 python divmod() 函数把除数和余数运算结果结合起来&#xff0c;返回一个包含商和余数的元组(a // b, a % b)。 在 python 2.3 版本之前不允许处理复数。 函数语法 divmod(a, b)参数说明&#xff1a; a: 数字b: 数字实例 >>>div…

蓝桥杯第六届省赛JAVA真题----垒骰子

垒骰子 赌圣atm晚年迷恋上了垒骰子&#xff0c;就是把骰子一个垒在另一个上边&#xff0c;不能歪歪扭扭&#xff0c;要垒成方柱体。 经过长期观察&#xff0c;atm 发现了稳定骰子的奥秘&#xff1a;有些数字的面贴着会互相排斥&#xff01; 我们先来规范一下骰子&#xff1a;1 …

并发队列、线程池、锁

1、CountDownLatch(计数器) CountDownLatch 类位于java.util.concurrent包下&#xff0c;利用它可以实现类似计数器的功能。比如有一个任务A&#xff0c;它要等待其他任务执行完毕之后才能执行&#xff0c;此时就可以利用CountDownLatch来实现这种功能了。CountDownLatch是…

蓝桥杯第七届省赛JAVA真题----剪邮票

剪邮票 如【图1.jpg】, 有12张连在一起的12生肖的邮票。 现在你要从中剪下5张来&#xff0c;要求必须是连着的。 &#xff08;仅仅连接一个角不算相连&#xff09; 比如&#xff0c;【图2.jpg】&#xff0c;【图3.jpg】中&#xff0c;粉红色所示部分就是合格的剪取。 请你…

目标检测之YOLO V2 V3

YOLO V2 YOLO V2是在YOLO的基础上&#xff0c;融合了其他一些网络结构的特性&#xff08;比如&#xff1a;Faster R-CNN的Anchor,GooLeNet的\(1\times1\)卷积核等&#xff09;&#xff0c;进行的升级。其目的是弥补YOLO的两个缺陷&#xff1a; YOLO中的大量的定位错误和基于区域…

蓝桥杯第八届省赛JAVA真题----迷宫

标题&#xff1a;迷宫 X星球的一处迷宫游乐场建在某个小山坡上。 它是由10x10相互连通的小房间组成的。 房间的地板上写着一个很大的字母。 我们假设玩家是面朝上坡的方向站立&#xff0c;则&#xff1a; L表示走到左边的房间&#xff0c; R表示走到右边的房间&#xff0…

掌握MySQL数据库这些优化技巧,事半功倍!

一个成熟的数据库架构并不是一开始设计就具备高可用、高伸缩等特性的&#xff0c;它是随着用户量的增加&#xff0c;基础架构才逐渐完善。这篇文章主要谈谈MySQL数据库在发展周期中所面临的问题及优化方案&#xff0c;暂且抛开前端应用不说&#xff0c;大致分为以下五个阶段&am…

蓝桥杯第八届省赛JAVA真题----方格分割

标题&#xff1a;方格分割 6x6的方格&#xff0c;沿着格子的边线剪开成两部分。 要求这两部分的形状完全相同。 如图&#xff1a;p1.png, p2.png, p3.png 就是可行的分割法。 试计算&#xff1a; 包括这3种分法在内&#xff0c;一共有多少种不同的分割方法。 注意&#xff…

Python猫荐书系列:文也深度学习,理也深度学习

最近出了两件大新闻&#xff0c;相信大家可能有所耳闻。 我来当个播报员&#xff0c;给大家转述一下&#xff1a; 1、中国队在第 11 界罗马尼亚数学大师赛&#xff08;RMM&#xff09;中无缘金牌。该项赛事是三大国际赛事之一&#xff0c;被誉为中学奥数的最高难度。其中一道题…

NCRE四级网络工程师考题详解----LRU与LFU的区别

最近最少使用页面置换算法&#xff08;LRU&#xff09;淘汰的是最长时间不使用的 最近最不常用页面置换算法&#xff08;LFU&#xff09;淘汰的是一定时间内未被使用的 我们假设有主存块为3&#xff0c;所需页面的走向为2 1 2 1 2 3 4 注意,当调页面4时会发生缺页中断 若按L…

移动端与PC端页面布局区别

视口 视口是移动设备上用来显示网页的区域&#xff0c;一般会比移动设备可视区域大&#xff0c;宽度可能是980px或者1024px&#xff0c;目的是为了显示下整个为PC端设计的网页&#xff0c;这样带来的后果是移动端会出现横向滚动条&#xff0c;为了避免这种情况&#xff0c;移动…

蓝桥杯历届试题----斐波那契(矩阵快速幂)

问题描述 斐波那契数列大家都非常熟悉。它的定义是&#xff1a; f(x) 1 …. (x1,2) f(x) f(x-1) f(x-2) …. (x>2) 对于给定的整数 n 和 m&#xff0c;我们希望求出&#xff1a; f(1) f(2) … f(n) 的值。但这个值可能非常大&#xff0c;所以我们把它对 f(m) 取模…