• [模拟退火][UVA10228] A Star not a Tree?


    好的,在h^ovny的安利下做了此题

    模拟退火中的大水题,想当年联赛的时候都差点打了退火,正解貌似是三分套三分,我记得上一道三分套三分的题我就是退火水过去的...

    貌似B班在讲退火这个大玄学...

    这题还是比较简单的啦~

    随机化坐标x,y就可以啦

    然而格式错了n遍.....死的心都有了

    最后输出是四舍五入!!!四舍五入!!!四舍五入!!!

    两组答案中间有空行!!!有空行!!!有空行!!!

     

    然后只要会退火的板子就可以啦

    //LevenKoko
    #include<bits/stdc++.h> using namespace std; inline int read(){ int ans=0,f=1;char chr=getchar(); while(!isdigit(chr)){if(chr=='-')f=-1;chr=getchar();} while(isdigit(chr)) {ans=(ans<<3)+(ans<<1)+chr-48;chr=getchar();} return ans*f; } int x[1005],y[1005],n; double ansx,ansy,ans; const double delta=0.998; inline double DIS(double x1,double x2,double y1,double y2){return sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));} //欧几里得距离 inline double Get_Ans(double a,double b){double ans=0;for(int i=1;i<=n;i++)ans+=DIS(x[i],a,y[i],b);return ans;} //当前坐标答案 inline void Fire(){//退火板子 double T=19260 /*817*/ ,fx=ansx,fy=ansy; while(T>1e-8){ double tx=T*(rand()*2-RAND_MAX)+fx; double ty=T*(rand()*2-RAND_MAX)+fy;//这里调参,乱调就好了(脸白的无所畏惧),但是前面的随机数一定要能够取到负值啊(虽然我没试过不取会不会炸) double tans=Get_Ans(tx,ty); double DE=tans-ans; if(DE<0)ans=tans,fx=ansx=tx,fy=ansy=ty; else if(exp(-DE/T)*RAND_MAX>rand()) fx=tx,fy=ty; T*=delta; } } int main(){ int T=read(); while(T--){ n=read(); for(int i=1;i<=n;i++) x[i]=read(),y[i]=read(); ansx=ansy=0;ans=Get_Ans(0,0); for(int i=1;i<=10;i++) Fire(); cout<<(int)(ans+0.5); if(T) puts("");puts(""); } return 0; }
  • 相关阅读:
    异常处理
    泛型介绍
    Echart可视化学习(十)
    终Echart可视化学习(十二)
    Echart可视化学习(九)
    Echart可视化学习(十一)
    Ubuntu版本介绍
    大数据量分页存储过程效率测试附代码
    把 ubuntu linux 装入移动硬盘,并在不同电脑上运行
    后来才知道linux中的0、1、2、4、+、、u、g、o、a、=、r、w、x、d、、l、s、p、c、b非常重要
  • 原文地址:https://www.cnblogs.com/zhenglw/p/11180940.html
Copyright © 2020-2023  润新知