C. Theofanis‘ Nightmare

2024-01-29 12:28
文章标签 nightmare theofanis

本文主要是介绍C. Theofanis‘ Nightmare,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Theofanis 在入睡前很容易沉迷于各种问题,经常做噩梦。为了解决这个问题,他去看了他的医生 Emix 博士。
在他最近的噩梦中,他有一个大小为 n 的数组 a ,想把它分成非空的子数组,使得每个元素都正好在其中一个子数组中。
例如,数组 [1,−3,7,−6,2,5] 可以划分为 [1][−3,7][−6,2][5] 。
这种分割的塞浦路斯值等于 \sum_{i=1}^{k} i⋅sumi,其中 k 是我们将数组分割成的子数组的个数,sumi 是第 i 个子数组的和。
这个数组的塞浦路斯值为 [1][−3,7][−6,2][5]=1⋅1+2⋅(−3+7)+3⋅(−6+2)+4⋅5=17 。
Theofanis 想知道任何数组划分的最大塞浦路斯值是多少。
数组 b 是数组 a 的子数组,如果 b 可以从 a 中通过删除开头的几个(可能是零个或全部)元素和结尾的几个(可能是零个或全部)元素得到。特别地,一个数组是它自身的一个子数组。

输入
第一行包含一个整数 t ( 1 ≤ t ≤ 1e4 ) - 测试用例的数量。
每个测试用例由两行组成。每个测试用例的第一行包含一个整数 n (1 ≤ n ≤ 1e5) - 数组的大小。
第二行包含 n 个整数 a1,a2,…,an (−1e8 ≤ ai ≤ 1e8) - 数组的元素。
保证所有测试用例的 n 之和不超过 2e5 。

输出
为每个测试用例打印一个整数,即数组 a 的最大塞浦路斯值。

Input
4
6
1 -3 7 -6 2 5
4
2 9 -5 -3
8
-3 -4 2 -5 1 10 17 23
1
830

Output
32
4
343
830

注:
在第一个测试案例中,为了得到塞浦路斯的最大值,我们将数组分成 [1][−3][7][−6][2][5] ,这样就得到了:

\sum_{i=1}^{k} i⋅sumi=1⋅1+2⋅(−3)+3⋅7+4⋅(−6)+5⋅2+6⋅5=32
同样,在第二个测试用例中,我们将数组分成 [2][9,−5,−3] ,得到 \sum_{i=1}^{k} i⋅sumii=1⋅2+2⋅(9+(−5)+(−3))=4 。

#include <bits/stdc++.h>
using namespace std;
#define int long long
#define endl '\n'
#define ios ios::sync_with_stdio(false),cin.tie(nullptr),cout.tie(nullptr);
int gcd(int a,int b) { return b? gcd(b,a%b) : a; }
typedef pair<int,int> PII;
const double PI=acos(-1.0);
const int N=2e6+10;
int n;
int a[N],p[N];
vector <int> ans;
void solve()
{cin>>n;for (int i=1;i<=n;i++) cin>>a[i];ans.clear();int sum=0;int res=0;for (int i=n;i>0;i--){sum +=a[i];res +=a[i];if (sum>0||i==1){ans.push_back(res);res=0;}}reverse(ans.begin(),ans.end());sum=0;for (int i=0;i<ans.size();i++) sum +=ans[i]*(i+1);cout<<sum<<endl;
}
signed main()
{ios;int T=1;cin>>T;while (T--) solve(); return 0;
}

这篇关于C. Theofanis‘ Nightmare的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/656897

相关文章

POJ 1984 Navigation Nightmare 二维带权并查集

题目来源:POJ 1984 Navigation Nightmare 题意:给你一颗树 k次询问 求2点之间的曼哈顿距离 并且要在只有开始k条边的情况下 思路:按照方向 我是以左上角为根 左上角为原点 dx[i]为i点距离根的x坐标 dy[]是y坐标 这两个可以通过路径压缩求出 只不过是二维而已 #include <cstdio>#include <cstdlib>#include <c

hdu 1072 Nightmare(BFS法和DFS法)

原题链接: http://acm.hdu.edu.cn/showproblem.php?pid=1072 题目大意: 0为墙1为路2为起点3为终点4为炸弹 走到任意一个炸弹都可以将所有炸弹重置倒计时6minutes 每走一个位置需要1minutes 问从2到3需要的最少时间 DFS法更快。 BFS法好理解。 思路: 两种方法都需理解一点: 同一个炸弹位置当第二次

网络游戏:为什么失败(转自CSDN之Nightmare的BLOG)

网络游戏:为什么失败  继互联网、电子商务、软件培训后,网络游戏是又一个被炒得过热的领域。随着钞票疯狂的砸下来,血拼的优胜劣汰进程也就开始了,如果不能走向成熟,就会走向失败。  开始的时候依靠的是概念和狂热,或者爆发或者默默消亡。第二批开始有竞争,但出于抢站市场的欲望,不论输赢都可以继续砸钱。第三批就是不理智的stampede,一拥而上,不想被踩死就要跑在最前面。  常见错误1:包罗万象的目标有远