题意:2^n支队伍进行淘汰赛,每一轮都是第一个与第二个,第三个与第四个比赛,给出了这些人之间的胜率,赢了的进入下一轮,相对位置不变。一共n轮比赛。问哪支队伍n轮比赛后的胜率最大。(n<=7)

#include <cstdio>
using namespace std;
const int N2=(1<<7)+5, N=8;
double d[N2][N], a[N2][N2];
int p[N2][N], n, n2;
int main() {
	for(int i=1; i<=128; ++i) p[i][1]=i-1;
	for(int i=1; i<=128; ++i) for(int j=2; j<=7; ++j) p[i][j]=p[i][j-1]>>1;
	while(scanf("%d", &n), ~n) {
		n2=1<<n;
		for(int i=1; i<=n2; ++i) for(int j=1; j<=n2; ++j) scanf("%lf", &a[i][j]);
		for(int i=1; i<=n2; ++i) d[i][0]=1;
		for(int j=1; j<=n; ++j) for(int i=1; i<=n2; ++i) {
			int pos=p[i][j]^1;
			double sum=0;
			for(int k=1; k<=n2; ++k) if(p[k][j]==pos)
				sum+=d[k][j-1]*a[i][k];
			d[i][j]=d[i][j-1]*sum;
		}
		int ans; double mx=-1;
		for(int i=1; i<=n2; ++i) if(d[i][n]>mx) { mx=d[i][n]; ans=i; }
		printf("%d\n", ans);
	}
	return 0;
}

  

设d[i][j]表示第i个人第j轮比赛的胜率,最后比较d[i][n]就是答案

显然:

d[i][0]=1;

d[i][j]=d[i][j-1]\sum_{k=1}^{T} d[b[k]][j-1]*a[i][b[k]], b[k]表示第j场比赛可能会与i决斗的人的标号

然后乱搞就行了= =

 

 本文为博主原创文章,未经博主允许不得转载。一经发现,必将追究法律责任。