unicornication - 3 years ago 128

Python Question

I have a 2d array,

`X`

`[0, 0, 0, 2, 1]`

[1, 2, 1, 0, 1]

[2, 2, 1, 0, 0]

[0, 0, 1, 2, 0]

I'm trying to iterate through the entire 2D array to try and count all the instances where there are 2 consecutive elements in a column. E.g.

`X`

`X[1][1] == X[2][1] && X[1][2] == X[2][2] && X[2][2] == X[3][2]`

I'm finding this very hard to visualize. So far I have:

`def get_opposite(number):`

if number == 2: return 1

if number == 1: return 2

def counter(X, number):

count = 0

for i in range(len(X)):

for j in range(len(X[i])-1):

if X[i][j] == X[i][j+1] and X[i][j] != 0 and X[i][j] != get_opposite(number):

count += 1

return count

I keep either getting vastly incorrect results, or IndexError, it should be fairly straight forward but I'm not sure what I'm doing wrong

Recommended for you: Get network issues from **WhatsUp Gold**. **Not end users.**

Answer Source

If you compare the example you give in the text with your actual code, you'll notice your code is comparing with the value on the *right*, not the with the value *below* it. You need to apply `+1`

to the first index, not the second. This also means the range of your loops has to be adapted accordingly.

Secondly, you don't need the first function. The equality comparison is enough.

Also, I removed the second argument of the function, as it serves no role:

```
def counter(X):
count = 0
for i in range(len(X)-1):
for j in range(len(X[i])):
if X[i][j] == X[i+1][j] and X[i][j] != 0:
count += 1
return count
```

Recommended from our users: **Dynamic Network Monitoring from WhatsUp Gold from IPSwitch**. ** Free Download**