about summary refs log tree commit diff
path: root/NTU/chenhlech.c
diff options
context:
space:
mode:
authorRaphael McSinyx <vn.mcsinyx@gmail.com>2016-10-08 09:56:43 +0700
committerRaphael McSinyx <vn.mcsinyx@gmail.com>2016-10-08 09:56:43 +0700
commit2a7bc10f6c011d19fb3b0e73068f7e1a9c30ace0 (patch)
tree95190a32ec1c7098494849eea5a5ba6b53289585 /NTU/chenhlech.c
parent207cc2ae9893b0cdecd20119b9ede37f73cd4a1e (diff)
downloadcp-2a7bc10f6c011d19fb3b0e73068f7e1a9c30ace0.tar.gz
Initial commit
Diffstat (limited to 'NTU/chenhlech.c')
-rw-r--r--NTU/chenhlech.c41
1 files changed, 41 insertions, 0 deletions
diff --git a/NTU/chenhlech.c b/NTU/chenhlech.c
new file mode 100644
index 0000000..27490bb
--- /dev/null
+++ b/NTU/chenhlech.c
@@ -0,0 +1,41 @@
+#include <stdlib.h>
+#include <stdio.h>
+
+unsigned long long delta(long *a, short len)
+{
+	unsigned long long sum = 0, val, val0, left = 0;
+	short i;
+
+	for (i = 0; i <= len; i++)
+		sum += a[i];
+	val = sum;
+
+	for (i = 0; i < len; i++) {
+		left += a[i];
+		val0 = llabs(sum - left * 2);
+		if (val0 < val)
+			val = val0;
+	}
+
+	return val;
+}
+
+int main()
+{
+	short n, q, *u, *v, i;
+	scanf("%hd %hd", &n, &q);
+
+	long *a = malloc(n * 4);
+	for (i = 0; i < n; i++)
+		scanf("%ld", &a[i]);
+
+	u = malloc(q * 2);
+	v = malloc(q * 2);
+	for (i = 0; i < q; i++)
+		scanf("%hd %hd", &u[i], &v[i]);
+
+	for (i = 0; i < q; i++)
+		printf("%lld\n", delta(a + u[i] - 1, v[i] - u[i]));
+
+	return 0;
+}