Loading

HDU6672 Lead of Wisdom(爆搜)

Lead of Wisdom

In an online game, "Lead of Wisdom" is a place where the lucky player can randomly get powerful items.

img

There are k types of items, a player can wear at most one item for each type. For the i

-th item, it has four attributes \(a_i,b_i,c_i\)

and \(d_i\). Assume the set of items that the player wearing is S

, the damage rate of the player DMG

can be calculated by the formula:

\(DMG=(100+\Sigma a_i)(100+\Sigma b_i)(100+\Sigma c_i)(100+\Sigma d_i)\)

Little Q has got n

items from "Lead of Wisdom", please write a program to help him select which items to wear such that the value of DMG is maximized.

Input

The first line of the input contains a single integer T

(1≤T≤10), the number of test cases.

For each case, the first line of the input contains two integers n

and k (1≤n,k≤50), denoting the number of items and the number of item types.

Each of the following n lines contains five integers \(t_i*,*a_i,b_i,c_i, d_i\)

$ (1≤t_i≤k,0≤a_i,b_i,c_i,d_i≤100)$, denoting an item of type \(t_i\)

whose attributes are $a_i,b_i,c_i $and \(d_i\)

.

Output

For each test case, output a single line containing an integer, the maximum value of DMG

.

Sample Input

1
6 4
1 17 25 10 0
2 0 0 25 14
4 17 0 21 0
1 5 22 0 10
2 0 16 20 0
4 37 0 0 0

Sample Output

297882000

暴力签到,对于这个数据规模直接爆搜即可,复杂度证明。可以用数组模拟一下链表,跳过没用的组。

当时没做出来,反思一下:当时写A有点怀疑人生,加上队友告诉我是个DP,加上判断题目类型的能力很弱....其实还是自己辣鸡T^T

这题本地跑了14s一度以为哪里出问题了,没想到交上去过了2333

#include <bits/stdc++.h>
using namespace std;
struct item
{
	long long a, b, c, d;
};
vector<vector<item> > v;
int n, k;
long long ans = -1e18;
int Next[55];
void dfs(int x, long long a, long long b, long long c, long long d)
{
	if(x == -1)
	{
		long long sum = a * b * c * d;
		ans = max(ans, sum);
		return;
	}
	for(int i = 0; i < v[x].size(); i++)
	{
		dfs(Next[x], a + v[x][i].a, b + v[x][i].b, c + v[x][i].c, d + v[x][i].d);
	}
}
int main()
{
	//freopen("1010.in","r",stdin);
	//freopen("myout.out","w",stdout);
	int Case;
	cin >> Case;
	for(int i = 1; i <= 51; i++)
	{
		vector<item> temp;
		v.push_back(temp);
	}
	while(Case--)
	{
		cin >> n >> k;
		ans = -1e18;
		set<int>s;
		//memset(Next, 0, sizeof(Next));
		long long sa = 100, sb = 100, sc = 100, sd = 100;
		for(int i = 1; i <= 51; i++)
		{
			v[i].clear();
		}
		for(int i = 1; i <= n; i++)
		{
			int t, a, b, c, d;
			scanf("%d%d%d%d%d", &t, &a, &b, &c, &d);
			v[t].push_back(item{a, b, c, d});
			s.insert(t);
		}
		set<int>::iterator it;
		int start, before;
		bool began = 0;
		for(it = s.begin(); it != s.end(); it++)
		{
			if(v[*it].size() == 1)
			{
				sa += v[*it][0].a;
				sb += v[*it][0].b;
				sc += v[*it][0].c;
				sd += v[*it][0].d;
			}
			else if(!began) 
			{
				start = before = *it;
				began = 1;
			}
			else 
			{
				Next[before] = *it;
				before = *it;
			}
		}
		Next[before] = -1;
		dfs(start, sa, sb, sc, sd);
		cout << ans << endl;
	}
	return 0;
}
posted @ 2020-07-27 09:05  脂环  阅读(167)  评论(0编辑  收藏  举报