2013. Pay Back"Never a borrower nor a lender be." O how Bessie wishes she had taken that advice! She has borrowed from or lent money to each of N (1 ≤ N ≤ 100,000) friends, conveniently labeled 1..N.
Payback day has finally come. She knows she is owed more money than she owes to the other cows. They have all lined up in a straight line, cow i standing i meters from the barn. Bessie is going to traverse the line collecting money from those who owe her and reimbursing money to those she owes.
As she moves down the line, she can request any cow who owes her money to give her the money. When she has enough money to pay off any or all of her debts, she can pay the (recently collected) money to those she owes. Cow i owes Bessie D_i money (-1,000 ≤ D_i ≤ 1,000; D_i != 0). A negative debt means that Bessie owes money to the cow instead of vice-versa.
Bessie starts at the barn, location 0. What is the minimum distance she must travel to collect her money and pay all those she owes? She must end her travels at the end of the line.
Line 1: A single integer: N Lines 2..N+1: Line i+1 contains a single integer: D_i
Line 1: A single integer that is the total metric distance Bessie must travel in order to collect or pay each cow.
5 100 -200 250 -200 200
9
◦問Bessie最少花費的時間
#include<iostream>
using namespace std;
int main()
{
int n;
cin>>n;
int arr[100001];
int sum=0;
int p,pace;
for(int i=0;i<n;i++)
{
cin>>arr[i];
}
for(int j=0;j<n;j++)
{
sum+=arr[j];
if(sum<0&&sum-arr[j]>=0)//從不欠錢到欠錢的過渡點,記錄下來
{
p=j;
}
else if(sum>=0&&sum-arr[j]<0)//從欠錢到不欠錢的過渡點,馬上回去還錢
{
pace+=j+j-p-p; //pace記錄回頭還錢走過的步數
}
}
pace+=n; //所走過的步數還要加上一路走來的
cout<<pace<<endl;
//system("pause");
return 0;
}