Solving Quadratic Equations in .NET


Hello, and welcome to my small article about Quadratic Equations.

Quadratic Equations

In algebra, a quadratic equation is any equation in the form of ax2 + bx + c = 0. In the previous expression, x represents an unknown, and a, b, and c represent known numbers such that a is not equal to 0. The numbers a, b, and c are the coefficients of the equation, and can be distinguished by calling them the quadratic coefficient, the linear coefficient, and the constant or free term.

Our Project

Use Visual Studio to create either a VB.NET or a C# Windows Forms Application and design the form to resemble Figure 1.

Figure 1: Design

Please note that my naming of objects may be different than yours.


Add the following namespaces to your code:


using System;
using System.Windows.Forms;


Imports System.Math

Add the following fields to your form.


      private double sngCoEffA;
      private double sngCoEffB;
      private double sngCoEffC;

      private double sngDiscriminant;

      private double sngRoot1;
      private double sngRoot2;


   Private sngCoEffA As Double
   Private sngCoEffB As Double
   Private sngCoEffC As Double

   Private sngDiscriminant As Double

   Private sngRoot1 As Double
   Private sngRoot2 As Double

In the preceding code, you have created the Coefficient objects, Discriminant objects, as well as the Root objects. Add the following code for the Calculate button.


      private void btnCalculate_Click(object sender, EventArgs e)

         sngCoEffA = float.Parse(txtCoEfficient1.Text.ToString());
         sngCoEffB = float.Parse(txtCoEfficient2.Text.ToString());
         sngCoEffC = float.Parse(txtCoEfficient3.Text.ToString());

         sngDiscriminant = (sngCoEffB * sngCoEffB) - (4 * sngCoEffA
            * sngCoEffC);

         if ((sngDiscriminant > 0))

            sngRoot1 = (-sngCoEffB + Math.Sqrt(sngDiscriminant)) /
               (2 * sngCoEffA);
            sngRoot2 = (-sngCoEffB - Math.Sqrt(sngDiscriminant)) /
               (2 * sngCoEffA);

            txtRoot1.Text = sngRoot1.ToString();
            txtRoot2.Text = sngRoot2.ToString();

         else if ((sngDiscriminant == 0))

            sngRoot1 = (-sngCoEffB + Math.Sqrt(sngDiscriminant)) /
               (2 * sngCoEffA);

            MessageBox.Show("One Root");

            txtRoot1.Text = sngRoot1.ToString();


            MessageBox.Show("No Root");



   Private Sub btnCalculate_Click(ByVal sender As System.Object, _
         ByVal e As System.EventArgs) Handles btnCalculate.Click

      sngCoEffA = txtCoEfficient1.Text
      sngCoEffB = txtCoEfficient2.Text
      sngCoEffC = txtCoEfficient3.Text

      sngDiscriminant = (sngCoEffB * sngCoEffB) - (4 * sngCoEffA _
         * sngCoEffC)

      If (sngDiscriminant > 0) Then

         sngRoot1 = (-sngCoEffB + Math.Sqrt(sngDiscriminant)) / _
            (2 * sngCoEffA)
         sngRoot2 = (-sngCoEffB - Math.Sqrt(sngDiscriminant)) / _
            (2 * sngCoEffA)

         txtRoot1.Text = sngRoot1
         txtRoot2.Text = sngRoot2

      ElseIf (sngDiscriminant = 0) Then

         sngRoot1 = (-sngCoEffB + Math.Sqrt(sngDiscriminant)) / _
            (2 * sngCoEffA)

         MessageBox.Show("One Root")

         txtRoot1.Text = sngRoot1


         MessageBox.Show("No Root")

      End If

   End Sub

The code for the calculate button works out the Quadratic Equation based on the values that were input. When run, the Form might resemble Figure 2.

Figure 2: Running


Quadratic Equations might seem scary and daunting, especially when complicated formulas are involved. Hopefully, in a follow-up article I can explain a different technique. Until then, happy coding!

This article was originally published on June 1st, 2018

About the Author

Hannes DuPreez

Hannes du Preez is a self-taught developer who started learning to program in the days of QBasic. He has written several articles over the years detailing his programming quests and adventures. .NET is his second love, just after his wife and kid. He has always been an avid supporter of .NET since the beginning and is an expert in VB and C#. He was given the Microsoft Most Valuable Professional Award for .NET (2008–2017). He has worked as a moderator and an article reviewer on online forums and currently works as a C# developer and writes articles for CodeGuru.com, Developer.com, DevX.com, and the Database journal.
His first book Visual Studio 2019 In Depth is currently on sale on Amazon and Bpb Publications.

You could reach him at: ojdupreez1978[at]gmail[dot]com

Related Articles

Most Popular Programming Stories

More for Developers

RSS Feeds

Thanks for your registration, follow us on our social networks to keep up-to-date