using System; using System.Collections; using System.Collections.Generic; using System.Linq; using System.Text; using System.IO; using System.Diagnostics; using System.Diagnostics.Contracts; using CT = System.Diagnostics.Contracts.Contract; using System.Numerics; class TEST{ static void Main(){ Sol mySol =new Sol(); mySol.Solve(); } } class Sol{ public void Solve(){ List L = new List(); long alpha = 0; // at least 1 solution with absolute value < 1e6 for(long j=0;j<1e6;j++){ if(j*j*j + A*j*j + B*j + C == 0){ alpha = j; L.Add(alpha); break; } if(-j*j*j + A*j*j - B*j + C == 0){ alpha = -j; L.Add(alpha); break; } } // solve 2-equation y^2 + A2*y + B2 = 0 // A = -(alpha + beta + gamma); B = alpha*beta + beta*gamma + gamma*alpha // -> A2 := -(beta + gamma) = A + alpha; // B2 = beta*gamma = B - alpha (beta + gamma) = B + alpha*A2; long A2 = 0; long B2 = 0; long D = 0; A2 = A + alpha; // -(beta + gamma) B2 = B + alpha*A + alpha*alpha; // beta * gamma D = A2*A2 - 4*B2; // determinant long sqrtD = (long)Math.Sqrt((double)D); L.Add( (-A2 + sqrtD)/2 ); L.Add( (-A2 - sqrtD)/2 ); L.Sort(); Console.WriteLine(String.Join(" ",L.ToArray())); } long A,B,C; public Sol(){ var d = rla(); A = d[0]; B = d[1]; C = d[2]; } static String rs(){return Console.ReadLine();} static int ri(){return int.Parse(Console.ReadLine());} static long rl(){return long.Parse(Console.ReadLine());} static double rd(){return double.Parse(Console.ReadLine());} static String[] rsa(char sep=' '){return Console.ReadLine().Split(sep);} static int[] ria(char sep=' '){return Array.ConvertAll(Console.ReadLine().Split(sep),e=>int.Parse(e));} static long[] rla(char sep=' '){return Array.ConvertAll(Console.ReadLine().Split(sep),e=>long.Parse(e));} static double[] rda(char sep=' '){return Array.ConvertAll(Console.ReadLine().Split(sep),e=>double.Parse(e));} }