import sympy as sp

def sign(a):
    """Return the sign of a (with sign(0) defined as -1)."""
    if a > 0:
        return 1
    elif a < 0:
        return -1
    else:
        return -1  # sign(0) = -1

def generate_x_range(n):
    """Generate x range from {-1, 1}^n (step size = 1, no 0 included)."""
    min_sum = -n
    max_sum = n
    return list(range(min_sum, max_sum + 1, 2))  # Only odd integers from -n to n

def polynomial_F_generalized(x_values, p):
    """Construct and return the polynomial F(x) modulo prime p."""
    x = sp.Symbol('x')
    F_x = sum(sign(a_i) * (1 - (x - a_i)**(p - 1)) for a_i in x_values)
    F_x = sp.simplify(F_x)
    F_poly = sp.Poly(sp.expand(F_x), x)
    coeffs_mod_p = [c % p for c in F_poly.all_coeffs()]
    return sum(coef * x**i for i, coef in enumerate(reversed(coeffs_mod_p)))

def main():
    try:
        n = int(input("Enter the number of elements n: "))
        k = 1  # fixed step size
        include_zero = False  # fixed option

        p = int(input("Enter a prime number p: "))
        x_values = generate_x_range(n)
        poly = polynomial_F_generalized(x_values, p)
        
        print(f"\nThe majority vote polynomial F(x) mod {p} is:")
        print(poly)

    except Exception as e:
        print("An error occurred:", e)

if __name__ == "__main__":
    main()