CodeForces 500C New Year Book Reading

链接:
New Year Book Reading

题意:
有n本书编号为1~n, 每本书的重量是wi,书可以按任意顺序叠成一摞。
对于这摞书进行m次操作,每次从中取出第bj本,取完之后把第bj本放在所有书的最上面,取一本书的代价是在它上面所有书重量之和,求m次操作总代价的最小值

思路:
原始的书的顺序按操作顺序来排,b1放在最上面,b2放在第二,以此类推。
开一个数组保存任意两本书的先后关系,每一次操作遍历一遍数组,结果加上在它之前的所有书的重量,并把它放在所有书之前

#include<bits/stdc++.h>
using namespace std;
const int MAXN = 507;
const int MAXM = 1007;
int w[MAXN];
int b[MAXM];
int top[MAXN][MAXN]; 
// top[i][j] : j在i上面
int main(int argc, char const *argv[])
{
	int n,m;
    //freopen("in.txt", "r", stdin); 
	while(~scanf("%d%d", &n, &m))
	{
		memset(top, 0, sizeof(top));
		for (int i = 1; i <= n; ++i)
		{
			scanf("%d", &w[i]);
		}
		for (int i = 1; i <= m; ++i)
		{
			scanf("%d", &b[i]);
		}
		long long ans = 0;
		for (int i = 1; i <= m; ++i)
		{
			for (int j = 1; j <= n; ++j)
			{
				if(b[i] == j) continue;
				if(top[ b[i] ][j] ) ans += w[j];
				top[b[i]][j] = 0;
				top[j][b[i]] = 1;
			}
		}

		printf("%I64d\n", ans);
	}
	return 0;
}
posted @ 2020-11-07 13:12  nanf0621  阅读(48)  评论(0编辑  收藏  举报