USACO- 结算日

题目描述

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

输入格式

第一行,一个整数 �N

接下来第 2…�+12…N+1 行,第 �+1i+1 行包含一个整数 ��Di

输出格式

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

输入输出样例

输入 #1

5

100

-200

250

-200

200

输出 #1

9

说明/提示

输入解释:

33 头奶牛欠贝西钱;她欠 22 头奶牛钱。当她完成结算,她将有 150150 元。

输出解释:

谷仓  100-200250-200200
 |     |     |    |    |    |
 ***>**+**>*****>**+
                   *            < 贝西有 350元
             -**<***
             *                  < 贝西有 150元
             ***>****>****>**+
                             *  < 贝西有 350
                       -**<***
                       *     
                       ***>***  < 贝西结束她的行走,有 150元

代码如下:

#include<cstdio>
int n,m,x,a,s=0;
int main(){
	scanf("%d",&n);
	x=n;
	for(int i=1;i<=n;i++){
		scanf("%d",&m);
		s+=m;
		if(s>=0&&a!=0){
			x+=(i-a)*2;
			a=0;
		}
		if(s<0&&a==0){
			a=i;
		}
	}
	printf("%d",x);
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值