洛谷 P1599 结算日

题目描述

“不放债不借债”,贝西多么希望自己可以遵循这个忠告。她已经和她的N(1 <= N <= 100,000)个朋友有了债务关系,或者借债了,或者放债了。她的N个朋友依次标号为1..N。 结算日终于来临了。她知道,朋友欠她的钱比她欠朋友的钱多。她的朋友们分布在一条直线上,第i头奶牛站的位置距离谷仓i米。贝西打算沿着这条直线行走,从欠她钱的奶牛手里收钱回来,并且还钱给她欠钱的奶牛。 当她沿直线移动的时候,她可以要求任何欠她钱的奶牛还全部的钱。当她有足够的钱可以还清她的某个债,就可以把钱给对应的奶牛还清她的债。奶牛i欠贝西D_i元(-1,000 <= D_i <=1,000; D_i <> 0),负数表示贝西欠奶牛i钱。 贝西从谷仓出发,位置为0,初始贝西没有钱。贝西收回她的所有借债,并且还清她的欠债所需行走的最短距离是多少?注意:她必须在最后一头奶牛所在的位置,完成她的行走。

输入输出格式

输入格式:

行1:一个整数:N 行2..N+1:第i+1行包含一个整数:Di

输出格式:

行1:一个整数,贝西收回借债并且还清欠债,所需要行走的最短距离(单位为米)

输入输出样例

输入样例#1: 复制

5
100
-200
250
-200
200
输出样例#1: 复制

9

说明

输入解释:

3头奶牛欠贝西钱;她欠2头奶牛钱。当她完成结算,她将有150元。

输出解释:

谷仓  100  -200  250 -200  200
| | | | | |
***>**+**>*****>**+
* < 贝西有 350元
-**<***
* < 贝西有 150元
***>****>****>**+
* < 贝西有 350
-**<***
*
***>*** < 贝西结束她的行走,有 150元
难度:普及- 思路:纯模拟(这道题要是是求完成结算她有多少钱就好了)
//短短的代码。。
#include<iostream>
using namespace std;
int n,x,sum,ans,l;
bool flag;
int main() {
cin >> n;
for (int i = ; i <= n; i++) {
cin >> x; sum += x; ans += ;
if((sum>=) && flag) { flag = ; ans += (i-l)*; }
if((sum<) && !flag) { flag = ; l = i; }
}
cout << ans;
}
 

最新文章

  1. angularjs + fis +modJS 对于支持amd规范的组建处理(PhotoSwipe 支持,百度webUpload支持)
  2. 【转】c#处理3种json数据的实例
  3. 【转】Timer还是Handler
  4. 通过Ajax post Json类型的数据到Controller
  5. 理解css中的line-height
  6. javascript优化--05模式(函数)
  7. LDA-math-神奇的Gamma函数
  8. 初识Less(2015年05月23日)
  9. JAVA解析XML的四种方式
  10. OD: SEHOP
  11. HDU5141--LIS again (LIS变形)
  12. Light oj 1030 二分查找
  13. 身在魔都的她,该不该继续&quot;坚持&quot;前端开发?
  14. CentOS7自定义系统服务示例
  15. Python selenium中注入并执行Javascript语句
  16. 洛谷P3247 [HNOI2016]最小公倍数 [分块,并查集]
  17. 擅于使用JS的eval方法
  18. crm创建启用停用用户
  19. Java乱码解决之道
  20. 所有权链(Ownership Chain)

热门文章

  1. Django_视图操作
  2. oracle 查询某个时间段数据
  3. C++虚表的原理,很好
  4. Unity3D:粒子系统Particle System
  5. android webview 报 [ERROR:in_process_view_renderer.cc(189)] Failed to request GL process. Deadlock likely: 0 问题
  6. 洛谷P3383 【模板】线性筛素数(Miller_Rabin)
  7. 关于html(meta的常用的用法)
  8. deep-in-es6(二)
  9. LuoguP4012 深海机器人问题(费用流)
  10. col---过滤控制字符