解题报告_18.5.26_POJ_1039_0

本文介绍了一种用于计算光线穿过管道时最远可见点位置的算法。该算法利用了叉积运算来判断光线与管道壁是否相交,并通过精确的交点计算确定光线的最大穿透距离。此外,还详细解释了如何通过枚举上、下折点来寻找能够完全贯穿管道的光线。

转载自:https://blog.youkuaiyun.com/lyy289065406/article/details/6648585

#include<iostream>  
#include<cmath>  
#include<iomanip>  
using namespace std;  
  
const double precision=1e-3;   //精度限制  
const double inf=99999.0;   //正无穷,注意下面使用的是负无穷  
  
typedef class Node    //折点坐标  
{  
public:  
    double x;  
    double y;  
}point;  
  
int max(int a,int b)  
{  
    return a>b?a:b;  
}  
  
/*把浮点p的值转化为0,1或-1  (精度讨论)*/  
  
int dblcmp(double p)  
{  
    if(fabs(p)<precision)    // fabs()  浮点数的绝对值  
        return 0;       //只要是在0的邻域,就认为是0  
  
    return p>0?1:-1;  
}  
  
/*叉积运算*/  
  
double det(double x1,double y1,double x2,double y2)  
{  
    return x1*y2-x2*y1;  
}  
  
/*计算P点在AB的左侧还是右侧(AC与AB的螺旋关系)*/  
  
double cross(point A,point B,point P)  
{  
    return det(B.x-A.x , B.y-A.y , P.x-A.x , P.y-A.y);  
}  
  
/*判断直线AB、CD是否相交*/  
  
bool check(point A,point B,point C,point D)  
{  
    return (dblcmp(cross(A,B,C)) * dblcmp(cross(A,B,D)) <= 0);  
    //这里对黑书P353所述模板的相交约束条件做了修改  
    //目的是允许 入射光线L 与 折点处垂线 不规范相交(即垂线的端点可以落在L上 或者 允许延长线相交)  
}  
  
/*计算直线AB、CD的交点横坐标*/  
//本题这里传参是有讲究的,AB是代表光线L与管道的交点,CD是代表上管壁或者下管壁的端点  
//之所以这样做,是因为AB与CD实质上是不相交的,是AB的延长线与CD相交  
//按照上述传参顺序,根据修改后的模板,那么仅仅判断C、D是否在AB的两侧,就能计算 AB延长线与CD的交点  
//倘若传参顺序错了,就会判断A、B是否在CD的两侧,但是AB一定是在CD同侧的,也就不能求交点了  
  
double intersection(point A,point B,point C,point D)  
{  
    double area1=cross(A,B,C);  
    double area2=cross(A,B,D);  
    int c=dblcmp(area1);  
    int d=dblcmp(area2);  
  
    if(c*d<0) //CD在AB的两侧,规范相交  
        return (area2*C.x - area1*D.x)/(area2-area1);  //黑书P357交点计算公式  
  
    if(c*d==0)   //CD的其中一个端点在AB上,不规范相交  
        if(c==0)  
            return C.x;//C在AB上,返回AB与CD非规范相交时的交点C的横坐标  
        else  
            return D.x;//D在AB上,返回AB与CD非规范相交时的交点D的横坐标  
  
    return -inf;  //CD在AB同侧,无交点,返回 负无穷  
}  
  
int main(int i,int j,int k)  
{  
    int n;    //折点数  
    while(cin>>n)  
    {  
        if(!n)  
            break;  
  
        point* up=new point[n+1];         //上折点  
        point* down=new point[n+1];       //下折点  
  
        double max_x=-inf;  //最大可见度(管中最远可见点的横坐标)  
        /*Input*/  
  
        for(i=1;i<=n;i++)  
        {  
            cin>>up[i].x>>up[i].y;  
            down[i].x=up[i].x;  
            down[i].y=up[i].y-1;  
        }  
  
        bool flag=false;  //标记当前光线L(直线up[i]->down[j])能否贯通全管  
        for(i=1;i<=n;i++) //枚举所有通过一个上折点、一个下折点的直线  
        {  
            for(j=1;j<=n;j++)  
                if(i!=j)  
                {  
                    for(k=1;k<=n;k++)     //直线L最大延伸到第k-1节管子  
                        if(!check(up[i],down[j],up[k],down[k]))   //up[k]->down[k]为折点处垂直x轴的直线  
                            break;  
  
                    if(k>n)  
                    {  
                        flag=true;  
                        break;  
                    }  
                    else if(k>max(i,j))  //由于不清楚L究竟是与第k-1节管子的上管壁还是下管壁相交,因此都计算交点,取最优  
                    {                   //举例:若实际L是与上管壁相交,当计算下管壁时,得到的是第k-1个下折点,并不会是最优  
                                        //反之亦同理   
                        double temp=intersection(up[i],down[j],up[k],up[k-1]);  
                        if(max_x < temp)  //L与第k-1节管子的上管壁相交  
                            max_x=temp;  
  
                        temp=intersection(up[i],down[j],down[k],down[k-1]);  
                        if(max_x < temp)  //L与第k-1节管子的上管壁相交  
                            max_x=temp;  
                    }  
                }  
  
            if(flag)  
                break;  
        }  
  
        if(flag)  
            cout<<"Through all the pipe."<<endl;  
        else  
            cout<<fixed<<setprecision(2)<<max_x<<endl;  
  
        /*Relax Room*/  
  
        delete up,down;  
    }  
    return 0;  
}  

【博士论文复现】【阻抗建模、验证扫频法】光伏并网逆变器扫频与稳定性分析(包含锁相环电流环)(Simulink仿真实现)内容概要:本文档围绕“博士论文复现”主题,重点介绍了光伏并网逆变器的阻抗建模与扫频法稳定性分析,涵盖锁相环和电流环的Simulink仿真实现。文档旨在通过完整的仿真资源和代码帮助科研人员复现相关技术细节,提升对新能源并网系统动态特性和稳定机制的理解。此外,文档还提供了大量其他科研方向的复现资源,包括微电网优化、机器学习、路径规划、信号处理、电力系统分析等,配套MATLAB/Simulink代码与模型,服务于多领域科研需求。; 适合人群:具备一定电力电子、自动控制或新能源背景的研究生、博士生及科研人员,熟悉MATLAB/Simulink环境,有志于复现高水平论文成果并开展创新研究。; 使用场景及目标:①复现光伏并网逆变器的阻抗建模与扫频分析过程,掌握其稳定性判据与仿真方法;②借鉴提供的丰富案例资源,支撑博士论文或期刊论文的仿真实验部分;③结合团队提供的算法与模型,快速搭建实验平台,提升科研效率。; 阅读建议:建议按文档目录顺序浏览,优先下载并运行配套仿真文件,结合理论学习与代码调试加深理解;重点关注锁相环与电流环的建模细节,同时可拓展学习其他复现案例以拓宽研究视野。
内容概要:本文系统解析了嵌入式通信协议栈系列项目的实践路径,围绕通信原理与工程实现,阐述在资源受限的嵌入式环境中构建稳定、可扩展通信能力的方法。文章从通信基础模型出发,强调分层设计思想,涵盖物理层到应用层的职责划分,并依次讲解通信驱动、数据收发机制、帧格式解析、状态机控制、错误处理等核心技术环节。项目实践注重底层可靠性建设,如中断响应、缓冲区管理与数据校验,同时关注上层应用对接,确保协议栈支持设备配置、状态上报等实际业务。文中还突出性能优化与资源管理的重要性,指导开发者在内存与处理效率间取得平衡,并通过系统化测试手段(如异常模拟、压力测试)验证协议栈的健壮性。; 适合人群:具备嵌入式系统基础知识,有一定C语言和硬件接口开发经验,从事或希望深入物联网、工业控制等领域1-3年工作经验的工程师。; 使用场景及目标:①掌握嵌入式环境下通信协议栈的分层架构设计与实现方法;②理解状态机、数据封装、异常处理等关键技术在真实项目中的应用;③提升在资源受限条件下优化通信性能与稳定性的工程能力; 阅读建议:建议结合实际嵌入式平台动手实践,边学边调,重点关注各层接口定义与模块解耦设计,配合调试工具深入分析通信流程与异常行为,以全面提升系统级开发素养。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值