solution.cpp 645 字节
Newer Older
每日一练社区's avatar
每日一练社区 已提交
1
#include <bits/stdc++.h>
每日一练社区's avatar
每日一练社区 已提交
2
using namespace std;
每日一练社区's avatar
每日一练社区 已提交
3 4 5

const int maxn = 100005;

每日一练社区's avatar
每日一练社区 已提交
6 7
int numv[maxn];
int v[maxn];
每日一练社区's avatar
每日一练社区 已提交
8 9 10 11 12 13 14 15 16 17 18 19 20 21

int dfs(int idx)
{
	if (idx == 0)
		return 0;

	if (idx == 1)
		return v[0] * v[1];

	int max_, a = 0x3f3f3f, b = 0x3f3f3f3f, c = 0;
	if (idx >= 2)
		a = (v[idx] * v[idx - 1] + dfs(idx - 2) + numv[idx - 2] * (v[idx] + v[idx - 1])); //与左边粘
	b = v[idx] * numv[idx - 1] + dfs(idx - 1);											  //与左边不粘
	c = min(a, b);
每日一练社区's avatar
每日一练社区 已提交
22 23
	return c;
}
每日一练社区's avatar
每日一练社区 已提交
24 25 26 27

int main()
{

每日一练社区's avatar
每日一练社区 已提交
28
	int n;
每日一练社区's avatar
每日一练社区 已提交
29 30 31 32 33 34 35 36 37 38
	scanf("%d", &n);
	for (int i = 0; i < n; i++)
	{
		scanf("%d", &v[i]);
		if (i == 0)
			numv[i] = v[i];
		numv[i] = numv[i - 1] + v[i];
	}

	printf("%d", dfs(n - 1));
每日一练社区's avatar
每日一练社区 已提交
39
}