模拟退火相关题目

模拟退火相关题目

1.计算函数最值(非单峰函数)

1.Strange fuction

题目传送门HDU2899

思路:本题的状态函数就是题目中的数学函数,因为是求最小值,所以每次取最小即可,其他细节见代码。

#include<bits/stdc++.h> 
using namespace std;
const double eps=1e-8;//终止温度 
double y;
double fun(double x){ //计算函数结果 
	return 6*pow(x,7.0)+8*pow(x,6.0)+7*pow(x,3.0)+5*pow(x,2.0)-y*x;
}
double solve(){
	double T=100;//初始温度 
	double delta=0.997;//降温系数 
	double x=50.0;//初始x 
	double now=fun(x),ans=now;//当前计算的函数值,ans最后的答案 
	while(T>eps){//如果没有降低终止温度 
		double nx=x+(rand()*2-RAND_MAX)*T;//随T的降低,对x的改变减少 T可能增加,可能减少 
		if(nx>=0&&nx<=100){//nx处于范围内 
			double nt=fun(nx);//计算nx的值 
			ans=min(ans,nt);//取最小 
			if(now-nt>eps){//如果新状态更小 
				x=nx,now=nt;//x取新状态,now=nt 
			}
		}
		T*=delta;//降温 
	}
	return ans;
}
int main(){
	int t;
	cin>>t;
	while(t--){
		cin>>y;
		printf("%.4lf\n",solve());
	}
	return 0;	
}

求平衡点。

题目传送门:P1337

本题的状态函数是:n个点距离答案坐标的距离*各自重量的求和 也是取最小。因为距离乘上重量 越小,代表重物的重力势能越低,也就越平稳。下面上代码。

#include<bits/stdc++.h>
using namespace std;
struct p{
	double x,y,w;
}a[1005];
const double eps=1e-18,delta=0.9986;// delta 玄学delta 一般越接近1得到的可行解精度越高 
int n;
double x,y,now;
double fun(double x,double y){ //状态函数 
	double sum=0,dx,dy;
	for(int i=1;i<=n;i++)
	{
		dx=x-a[i].x,dy=y-a[i].y;
		sum+=sqrt(dx*dx+dy*dy)*a[i].w;
	}
	return sum;
}
void sa(){
	double t=3000;
	while(t>eps){
		double nx=x+(rand()*2-RAND_MAX)*t,ny=y+(rand()*2-RAND_MAX)*t;
		double nt=fun(nx,ny),de=nt-now;
		if(de<0)
		{
			x=nx,y=ny,now=nt;
		}
		else if(exp(-de/t)*RAND_MAX>rand())
				x=nx,y=ny;
		t*=delta;
	}
} 
int main(){
	cin>>n;
	for(int i=1;i<=n;i++) cin>>a[i].x>>a[i].y>>a[i].w,x+=a[i].x,y+=a[i].y;
	x/=n,y/=n;
	now=fun(x,y);
	sa();
	printf("%.3lf %.3lf\n",x,y);
	return 0;
	
}
全部评论

相关推荐

感觉这一周太梦幻了,就像一个梦,很不真实~~~感觉这个暑期,我的运气占了99成,实力只有百分之一4.15上午&nbsp;腾讯csig&nbsp;腾讯云部门,面完秒进入复试状态4.16下午&nbsp;美团优选供应链部门,4.18上午发二面4.17晚上&nbsp;阿里国际一面,纯拷打,面完我都玉玉了4.18下午&nbsp;阿里国际二面,是我们leader面的我,很轻松~~4.18晚上&nbsp;约了hr面4.19上午&nbsp;hr面,下午两点口头oc4.19晚上&nbsp;意向书说起来我的暑期好像一次都没挂过~~~~~难道我是天生面试圣体?----------------------------------------------------------------------六个月前,我还是0项目0刷题,当时想的是先把论文发出来再去找实习。结果一次组会,老师打破了我的幻想(不让投B会,只让投刊或者A)我拿头投啊!!!然后就开始物色着找实习,顺便做完了mit的6.s081,但是基本上还是没刷过题目-----------------------------------------------------------------------11月&nbsp;&nbsp;一次偶然的机会,面进了某个耳机厂的手环部门,大概是做嵌入式的,用的是CPP。12月&nbsp;莫名其妙拿到了国创的面试机会,0基础四天速成java基础!居然也给我面过了hhhhh,可能是面试没写题吧入职国创后的几个月,一直没活,天天搁那看剧,都快忘了还有暑期实习这回事了~~~~命运的齿轮在2.26开始转动,因为这一天美团开了,我开始慌了,因为那时的我什么都不会。lc,八股,sql全部是0进度。然后就开始了女娲补天,上班刷题,下班继续做之前的开源,顺便学一学八股。3月到现在,lc也刷到快200了,一天最多提交了47次~~~~~~~~~~八股根据别人的面经总结和博客,写了快十万字的笔记~~~~~~~~~~简历上的实习经历和开源,也努力去深挖了,写了几万字的记录~~~~~~所以面试的时候,基本上都能cover了,面试官问到的基础基本都会,不基础的我就把他往我会的地方引。结果好像还不错,基本上每个面试官评价都挺好的emmmmmmmm
投递阿里巴巴等公司10个岗位
点赞 评论 收藏
转发
点赞 收藏 评论
分享
牛客网
牛客企业服务