更新凸包模板

#include<iostream>
#include<stdio.h>
#include<algorithm>
#include<string.h> 
#include<math.h> 
using namespace std;
//此凸包作用:逆时针输出凸包顶点,凸包边上的点不输出
//(要全部输出边上的点的话,暂时没想到咋办,囧)
  
struct point 
{  
int x,y; 
}p[105],res[105];  
double Dist(const point &arg1, const point &arg2)
 {
     return sqrt((double) ((arg1.x - arg2.x)*(arg1.x - arg2.x) + (arg1.y - arg2.y)*(arg1.y - arg2.y)) );
 }
int multi(int i,int top,point p2,point p1,point p0)
 {   
    return (p1.x-p0.x)*(p2.y-p0.y)-(p2.x-p0.x)*(p1.y-p0.y); 
 }
int mysort1(point a,point b) 
 {  
     if(a.y!=b.y) return a.y<b.y;//重大修改:下左点改为上左点
     //if(a.y!=b.y) return a.y>b.y;
     if(a.y==b.y&&a.x!=b.x) return a.x<b.x;
 }
 bool cmp(const point &a,const point &b)
 { 
     point temp=p[0];
     double xmt=(a.x-temp.x)*(b.y-temp.y)-(b.x-temp.x)*(a.y-temp.y);
     if(xmt)                          
          return xmt>0;
     return Dist(a,temp)<Dist(b,temp);
 }
 int main()
 {  
  int n,k,len;
  cin>>k;
  while(k--)
     {
      cin>>n;
      for(int i=0;i<n;i++)
          cin>>p[i].x>>p[i].y;
      sort(p,p+n,mysort1);//排序,找到最左下角的点
      res[0]=p[0];
      sort(p+1,p+n,cmp);//按照极角排序
      res[1]=p[1];
      int top=1;
      for(int i=2;i<n;i++)//i=2:好把共线的点弹出去
       { 
            while( top && multi(i,top,p[i],res[top],res[top-1])<=0) 
                top--;
            res[++top]=p[i];
       }  
      for(int i=0;i<=top;i++)
           cout<<res[i].x<<" "<<res[i].y<<endl;
 }
system("pause");
return 0;}
多源动态最优潮流的分布鲁棒优化方法(IEEE118节点)(Matlab代码实现)内容概要:本文介绍了基于Matlab代码实现的多源动态最优潮流的分布鲁棒优化方法,适用于IEEE118节点电力系统。该方法结合两阶段鲁棒模型与确定性模型,旨在应对电力系统中多源输入(如可再生能源)的不确定性,提升系统运行的安全性与经济性。文中详细阐述了分布鲁棒优化的建模思路,包括不确定性集合的构建、目标函数的设计以及约束条件的处理,并通过Matlab编程实现算法求解,提供了完整的仿真流程与结果分析。此外,文档还列举了大量相关电力系统优化研究案例,涵盖微电网调度、电动汽车集群并网、需求响应、储能配置等多个方向,展示了其在实际工程中的广泛应用价值。; 适合人群:具备一定电力系统基础知识和Matlab编程能力的研究生、科研人员及从事能源系统优化工作的工程师。; 使用场景及目标:①用于研究高比例可再生能源接入背景下电力系统的动态最优潮流问题;②支撑科研工作中对分布鲁棒优化模型的复现与改进;③为电力系统调度、规划及运行决策提供理论支持与仿真工具。; 阅读建议:建议读者结合提供的Matlab代码与IEEE118节点系统参数进行实操演练,深入理解分布鲁棒优化的建模逻辑与求解过程,同时可参考文中提及的其他优化案例拓展研究思路。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值