【 OJ 】 HDOJ1046 18年12月8日21:43 [ 40 ]

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/QingCoffe/article/details/84899562

此题虽然是水题,但是此类问题却不是一个水题

从图论的角度来看,TSP问题实质是在一个带权完全无向图中,找一个权值最小的Hamilton回路。由于该问题的可行解是所有顶点的全排列,随着顶点数的增加,会产生组合爆炸,它是一个NP完全问题。 
早期的研究者使用精确算法求解该问题,常用的方法包括:分枝定界法、线性规划法、动态规划法等。但是,随着问题规模的增大,精确算法将变得无能为力,因此,在后来的研究中,国内外学者重点使用近似算法或启发式算法,主要有遗传算法、模拟退火法、蚁群算法、禁忌搜索算法、贪婪算法和神经网络等。 
 

# include<iostream>
#include <iomanip>
using namespace std;
int main(void) {
	int n,nn;
	cin >> n; nn = 1;
	int c, k;
	double qrt2 = sqrt(2);
	while (n--) {
		cin >> c >> k;//输入长宽
		cout << "Scenario #" << nn++<<":\n";
		if (!(c & 1) || !(k & 1)) {
			cout.setf(ios::fixed);
			cout <<setprecision(2) << (double)c*k << endl;
		}
		else {
			cout.setf(ios::fixed);
			cout << setprecision(2) << (double)c*k+qrt2-1 << endl;
		}
		if (n)
			cout << endl;
	}
	system("pause");
	return 0;
}

最近没时间写这些东西,但是这些方法还是要写的.....先留着吧...

猜你喜欢

转载自blog.csdn.net/QingCoffe/article/details/84899562