A non-empty array A consisting of N integers is given. Array A represents numbers on a tape.
Any integer P, such that 0 < P < N, splits this tape into two non-empty parts: A[0], A[1], ..., A[P − 1] and A[P], A[P + 1], ..., A[N − 1].
The difference between the two parts is the value of: |(A[0] + A[1] + ... + A[P − 1]) − (A[P] + A[P + 1] + ... + A[N − 1])|
In other words, it is the absolute difference between the sum of the first part and the sum of the second part.
For example, consider array A such that:
A[0] = 3 A[1] = 1 A[2] = 2 A[3] = 4 A[4] = 3We can split this tape in four places:
- P = 1, difference = |3 − 10| = 7
- P = 2, difference = |4 − 9| = 5
- P = 3, difference = |6 − 7| = 1
- P = 4, difference = |10 − 3| = 7
Write a function:
def solution(A)
that, given a non-empty array A of N integers, returns the minimal difference that can be achieved.
For example, given:
A[0] = 3 A[1] = 1 A[2] = 2 A[3] = 4 A[4] = 3the function should return 1, as explained above.
Write an efficient algorithm for the following assumptions:
- N is an integer within the range [2..100,000];
- each element of array A is an integer within the range [−1,000..1,000].
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
sumarr.append(sumarr[i-1]+a)
totsum = sumarr[-1]
for s in sumarr:
if abs(2*s - totsum) < mindiff:
mindiff =
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
sumarr.append(sumarr[i-1]+a)
totsum = sumarr[-1]
for s in sumarr:
diff = abs(2*s - totsum)
if diff < mindiff:
mindiff = diff
return mindiff
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
sumarr.append(sumarr[i-1]+a)
totsum = sumarr[-1]
for s in sumarr:
diff = abs(2*s - totsum)
if diff < mindiff:
mindiff = diff
return mindiff
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
sumarr.append(sumarr[i-1]+a)
delete sumarr[0]
totsum = sumarr[-1]
for s in sumarr:
diff = abs(2*s - totsum)
if diff < mindiff:
mindiff = diff
return mindiff
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
sumarr.append(sumarr[i-1]+a)
del sumarr[0]
totsum = sumarr[-1]
for s in sumarr:
diff = abs(2*s - totsum)
if diff < mindiff:
mindiff = diff
return mindiff
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
sumarr.append(sumarr[i-1]+a)
del sumarr[0]
totsum = sumarr[-1]
for s in sumarr[]:
diff = abs(2*s - totsum)
if diff < mindiff:
mindiff = diff
return mindiff
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
sumarr.append(sumarr[i-1]+a)
del sumarr[0]
totsum = sumarr[-1]
for s in sumarr[:len(sumarr)-1]:
diff = abs(2*s - totsum)
if diff < mindiff:
mindiff = diff
return mindiff
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
sumarr.append(sumarr[i-1]+a)
del sumarr[0]
totsum = sumarr[-1]
for s in sumarr[:len(sumarr)-1]:
diff = abs(2*s - totsum)
if diff < mindiff:
mindiff = diff
return mindiff
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
sumarr.append(sumarr[i-1]+a)
del sumarr[0]
totsum = sumarr[-1]
for s in sumarr[:len(sumarr)-1]:
diff = abs(2*s - totsum)
print(diff)
if diff < mindiff:
mindiff = diff
return mindiff
2 6 2 2
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
sumarr.append(sumarr[i-1]+a)
del sumarr[0]
totsum = sumarr[-1]
p
for s in sumarr[:len(sumarr)-1]:
diff = abs(2*s - totsum)
print(diff)
if diff < mindiff:
mindiff = diff
return mindiff
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
sumarr.append(sumarr[i-1]+a)
del sumarr[0]
totsum = sumarr[-1]
print(sumarr, totsum)
for s in sumarr[:len(sumarr)-1]:
diff = abs(2*s - totsum)
print(diff)
if diff < mindiff:
mindiff = diff
return mindiff
[3, 1, 5, 5, 8] 8 2 6 2 2
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
sumarr.append(sumarr[i-1]+a)
del sumarr[0]
totsum = sumarr[-1]
print(sumarr, totsum)
for s in sumarr[:len(sumarr)-1]:
diff = abs(2*s - totsum)
print(diff)
if diff < mindiff:
mindiff = diff
return mindiff
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
print(i, a, sumarr)
sumarr.append(sumarr[i-1]+a)
del sumarr[0]
totsum = sumarr[-1]
print(sumarr, totsum)
for s in sumarr[:len(sumarr)-1]:
diff = abs(2*s - totsum)
print(diff)
if diff < mindiff:
mindiff = diff
return mindiff
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
print(i, a, sumarr)
sumarr.append(sumarr[i-1]+a)
del sumarr[0]
totsum = sumarr[-1]
print(sumarr, totsum)
for s in sumarr[:len(sumarr)-1]:
diff = abs(2*s - totsum)
print(diff)
if diff < mindiff:
mindiff = diff
return mindiff
0 3 [0] 1 1 [0, 3] 2 2 [0, 3, 1] 3 4 [0, 3, 1, 5] 4 3 [0, 3, 1, 5, 5] [3, 1, 5, 5, 8] 8 2 6 2 2
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
print(i, a, sumarr)
sumarr.append(sumarr[i]+a)
del sumarr[0]
totsum = sumarr[-1]
print(sumarr, totsum)
for s in sumarr[:len(sumarr)-1]:
diff = abs(2*s - totsum)
print(diff)
if diff < mindiff:
mindiff = diff
return mindiff
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
print(i, a,)
sumarr.append(sumarr[i-1]+a)
del sumarr[0]
totsum = sumarr[-1]
print(sumarr, totsum)
for s in sumarr[:len(sumarr)-1]:
diff = abs(2*s - totsum)
print(diff)
if diff < mindiff:
mindiff = diff
return mindiff
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
print(i, a, sumarr)
sumarr.append(sumarr[i]+a)
del sumarr[0]
totsum = sumarr[-1]
print(sumarr, totsum)
for s in sumarr[:len(sumarr)-1]:
diff = abs(2*s - totsum)
print(diff)
if diff < mindiff:
mindiff = diff
return mindiff
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
print(i, a, sumarr)
sumarr.append(sumarr[i]+a)
del sumarr[0]
totsum = sumarr[-1]
print(sumarr, totsum)
for s in sumarr[:len(sumarr)-1]:
diff = abs(2*s - totsum)
print(diff)
if diff < mindiff:
mindiff = diff
return mindiff
0 3 [0] 1 1 [0, 3] 2 2 [0, 3, 4] 3 4 [0, 3, 4, 6] 4 3 [0, 3, 4, 6, 10] [3, 4, 6, 10, 13] 13 7 5 1 7
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
# print(i, a, sumarr)
sumarr.append(sumarr[i]+a)
del sumarr[0]
totsum = sumarr[-1]
print(sumarr, totsum)
for s in sumarr[:len(sumarr)-1]:
diff = abs(2*s - totsum)
print(diff)
if diff < mindiff:
mindiff = diff
return mindiff
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
# print(i, a, sumarr)
sumarr.append(sumarr[i]+a)
del sumarr[0]
totsum = sumarr[-1]
# print(sumarr, totsum)
for s in sumarr[:len(sumarr)-1]:
diff = abs(2*s - totsum)
# print(diff)
if diff < mindiff:
mindiff = diff
return mindiff
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
# print(i, a, sumarr)
sumarr.append(sumarr[i]+a)
del sumarr[0]
totsum = sumarr[-1]
# print(sumarr, totsum)
for s in sumarr[:len(sumarr)-1]:
diff = abs(2*s - totsum)
# print(diff)
if diff < mindiff:
mindiff = diff
return mindiff
[2, 4, 9, 8, 7, 10, 21]
[1, 1]
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
# print(i, a, sumarr)
sumarr.append(sumarr[i]+a)
del sumarr[0]
totsum = sumarr[-1]
# print(sumarr, totsum)
for s in sumarr[:len(sumarr)-1]:
diff = abs(2*s - totsum)
# print(diff)
if diff < mindiff:
mindiff = diff
return mindiff
[2, 4, 9, 8, 7, 10, 21]
[1, 1]
# you can write to stdout for debugging purposes, e.g.
# print("this is a debug message")
def solution(A):
# write your code in Python 3.6
sumarr, mindiff = [0], 2e9
for i, a in enumerate(A):
# print(i, a, sumarr)
sumarr.append(sumarr[i]+a)
del sumarr[0]
totsum = sumarr[-1]
# print(sumarr, totsum)
for s in sumarr[:len(sumarr)-1]:
diff = abs(2*s - totsum)
# print(diff)
if diff < mindiff:
mindiff = diff
return mindiff
The solution obtained perfect score.