1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
#include<iostream>

using namespace std;

int main()
{
	ios_base::sync_with_stdio(0);
	long long n,m;
	cin >> n >> m;
	long long *ros, *sko, *takie, *dni;
	ros = new long long [n];
	sko = new long long [m];
	dni = new long long [m];
	takie = new long long [n];
	for(long long i=0;i<n;i++)
	{
		cin >> ros[i];
		takie[i]=ros[i];
	}
	for(long long i=0;i<m;i++)
		cin >> dni[i] >> sko[i];
	long long ost=dni[m-1];
	long long znacznik=0;
	long long ilosc=dni[0];
	for(;znacznik<m;znacznik++)
	{
		if(znacznik)
		{
			ilosc=dni[znacznik]-dni[znacznik-1];

			for(long long j=0;j<n;j++)
			ros[j]+=takie[j]*ilosc;
		}
		long long sum=0;
		long long skoszone=sko[znacznik];
		for(long long j=0;j<n;j++)
		{
			if(ros[j]>skoszone)
			{
				sum+=ros[j]-skoszone;
				ros[j]=skoszone;
			}else{
				continue;
			}
		}
		cout << sum << endl;
	}
	delete [] ros;
	delete [] sko;
	delete [] takie;
	delete [] dni;
	return 0;
}

/*
for(long long i=0;i<m;i++)
	{
		if(i)
		{
			for(long long j=0;j<n;j++)
				ros[j]+=takie[j];
		}
		long long sum=0;
		long long skoszone=sko[i];
		for(long long j=0;j<n;j++)
		{
			if(ros[j]>skoszone)
			{
				sum+=ros[j]-skoszone;
				ros[j]=skoszone;
			}else{
				continue;
			}
		}
		cout << sum << endl;
	}
*/