Python
import sympy as sympy

# Experiment-5 circuit
Example = [
    [0,0,5,1000],
    [0,1,2,1000],
    [0,1,4,1000],
    [0,1,5,1000],
    [0,2,3,1000],
    [0,2,4,1000],
    [0,4,5,1000],
    [1,0,1,5],
    [1,0,3,3.3]
]

# simple 3.3V into a 500R resistor
Example2 = [
    [0, 1, 0, 500],
    [1, 0, 1, 3.3]
]

# voltage divider - 5V into a 100/200 divider
Example3 = [
    [1, 0, 1, 5],
    [0, 1, 2, 100],
    [0, 2, 0, 200]
]

def solve(Circuit, Nnodes, Rval=0.001):
    U = [ sympy.symbols("U"+str(k)) for k in range(0,Nnodes) ]
    R = sympy.symbols('R')
    Y = [0]*Nnodes

    for type, i, j, value in Circuit:
        value = float(value)
        if type == 0:
            g = 1/value
        else:
            g = 1/R
        Y[i] += U[i]*g - U[j]*g
        Y[j] += U[j]*g - U[i]*g
        if type == 1:
            Y[i] += value/R
            Y[j] -= value/R
    Y.append(U[0])      # set U0 = 0
    Y.append(R-Rval)    # set R = Rval
    vars = U.copy()
    vars.append(R)
    print("Equations:")
    for y in Y:
        print("      0 =", y)
    sols = sympy.solve(Y, vars)[0]
    print("\nSolution:")
    for i,v in enumerate(vars):
        print("   {:>4} = {}".format(str(v), str(sols[i])))

solve(Example, 6)
# solve(Example2, 2)
# solve(Example3, 3)
Equations:
      0 = 0.001*U0 - 0.001*U5 + 2*U0/R - U1/R - U3/R + 8.3/R
      0 = 0.003*U1 - 0.001*U2 - 0.001*U4 - 0.001*U5 - U0/R + U1/R - 5.0/R
      0 = -0.001*U1 + 0.003*U2 - 0.001*U3 - 0.001*U4
      0 = -0.001*U2 + 0.001*U3 - U0/R + U3/R - 3.3/R
      0 = -0.001*U1 - 0.001*U2 + 0.003*U4 - 0.001*U5
      0 = -0.001*U0 - 0.001*U1 - 0.001*U4 + 0.003*U5
      0 = U0
      0 = R - 0.001
Solution:
     U0 = 0.0
     U1 = 4.99999617143341
     U2 = 4.11428383673643
     U3 = 3.30000081428302
     U4 = 4.04285452449287
     U5 = 3.01428356530876
      R = 0.00100000000000000