Documenti di Didattica
Documenti di Professioni
Documenti di Cultura
Una ecuacin de segundo grado es una expresin de la forma ax + bx + c = 0 donde a,b,c son
nmeros reales conocidos llamados coeficientes, y x es la incgnita, el valor desconocido.
Resolver una ecuacin de segundo grado es encontrar el valor o valores de x, que hacen que la
igualdad sea cierta. A esos valores les llamamos soluciones.
Recordars que la expresin que determina las soluciones de una ecuacin de 2 grado es
Una ecuacin de 2 grado tiene soluciones reales siempre y cuando el valor del
discriminante sea positivo o igual a cero.
En esta prctica pretendemos realizar una hoja de clculo que resuelva ecuaciones de 2 grado con
soluciones reales. Para que te hagas una idea, te mostramos a modo de ejemplo, en la figura 1, el
resultado de la prctica:
Comenzamos el ejercicio escribiendo todo el texto que nos aparecer en esta nueva hoja de
clculo:
1. En la celda C1 escribe: Resolucin de ecuaciones de 2 grado . La alineacin en esta celda es
centrada.
2. En la celda B3 se escribe: ax + bx + c = 0.
Nota:
Para escribir el exponente de la x utilizamos el cdigo ASCII que se utiliza para escribir caracteres
que no estn en el teclado. Para escribir el cuadrado de la x mientras se mantiene presionada la
tecla Alt en el teclado numrico (a la derecha) pulsamos las teclas que contienen los nmeros 253.
Ahora que ya has escrito el texto correspondiente a esta hoja de clculo, indicamos a
continuacin como has de introducir las frmulas necesarias para completar esta prctica.
Vamos a utilizar una de las funciones lgicas que posee Excel para que la hoja de clculo nos
informe segn el signo del discriminante, si la ecuacin posee o no soluciones:
La funcin que vamos a utilizar es la funcin SI que ya conoces, de la unidad 8. Para saber ms
sobre esta funcin recuerda que puedes consultar la Ayuda de Microsoft Excel.
1. En la celda E11 escribe todo seguido, respetando los parntesis, los puntos y comas, y las
comillas lo que a continuacin indicamos:
=SI(D11<0;"El discriminante es negativo";SI(D11=0;"El discriminante es cero";"El discriminante es
positivo"))
Todava podemos mejorar nuestra prctica insertando como objetos de dibujo las frmulas,
tal y como estamos acostumbrados a escribirlas. Es decir, el discriminante: , la raz del
discriminante y la expresin que determina las soluciones de la
ecuacin:
Para ello hemos de utilizar la herramienta de Office llamada Editor de ecuaciones. A continuacin
iremos detallando los pasos.
1. Sitate en la celda C11, y haz clic en el men Insertar, Objeto.
2. En el cuadro de la ventana localiza Microsoft Editor de ecuaciones y haz clic en el
botn Aceptar. En el caso de que no lo tengas contina en el siguiente apartardo. No obstante,
si realizas la prctica 5 llamada Microsoft Editor de ecuaciones, aprenders a instalarlo.
La figura 2 muestra la barra de herramientas del editor de ecuaciones
Ten en cuenta
que para desplazarte por la expresin que ests escribiendo con el editor de ecuaciones se utilizan
las teclas del cursor. Como ejemplo, observa la figura 3.
Puedes mejorar la presentacin de la prctica cambiando las fuentes, los anchos de columna,
bordes, sombreados de celda, etc.
Crear un programa que pida un nmero entero distinto de cero y nos muestre en pantalla un
mensaje indicndonos si el nmero es par o impar.
SOLUCIN
Crearemos un Label de solicitud del nmero, un Textbox de entrada, un Button (Command Button
en las versiones menos recientes de Visual Basic) y un Label para el clculo y el resultado. Le
ponemos los nombres y organizamos los controles en pantalla como nos parezca correcto (no
tiene por qu coincidir con lo que ponemos aqu). Los nombres que hemos empleado nosotros
son: LabelPideNum, TextNentero, ButtonHallar yLabelResultado.
Grficamente:
Hemos escrito el If ... Then Else como un bloque en vez de como una nica lnea. El motivo
para ello es que aporta mayor claridad y facilidad de interpretacin.
SOLUCIN
Usaremos tres Labels para pedir los parmetros a, b y c denominados Labela, Labelb y Labelc, y
tres TextBox para que el usuario introduzca datos (Texta, Textb y Textc) adems de un botn
(ButtonCalcular). Nosotros hemos aadido adems un mensaje de cabecera con un label
(LabelTitulo). Mostraremos primero el cdigo para versiones de Visual Basic ms recientes y
luego para versiones menos recientes. Ten en cuenta que la lgica de los programas es en
ambos casos igual, lo nico que vara son los detalles de la sintaxis.
If dNumber = 0 Then
LabelResultado.Text = "x1 = x2 = " & -bNumber / eNumber
Else
If dNumber > 0 Then
LabelResultado.Text = "x1 = " & (-bNumber + Math.Sqrt(dNumber)) / eNumber
LabelResultado.Text = LabelResultado.Text & vbCrLf & "x2 = " & (-bNumber -
Math.Sqrt(dNumber)) / eNumber
Else
LabelResultado.Text = "x1 = " & -bNumber / eNumber & " + " & Math.Sqrt(-dNumber) / eNumber
& " * " & Math.Sqrt(-dNumber) / eNumber & " * i"
End If
End If
End Sub
End Class
Nota: en versiones recientes de Visual Basic algunas letras estn reservadas y no pueden ser
usadas como nombres de variables. Por ejemplo la letra e. De ah que en vez de nombrar a las
variables como a, b, c, d, e las hayamos nombrado aNumber, bNumber, cNumber, dNumber y
eNumber.
Option Explicit
Rem Declaracin de variables
Dim a!, b!, c!, d!, e As Single
COMENTARIOS
El programa (ambas versiones de cdigo) "funciona", si bien tiene sus limitaciones. Prueba a
introducir los siguientes datos: a = 0, b = 3 y c = 1 . Te aparecern resultados extraos (o un
error como "Error 6 en tiempo de ejecucin. Desbordamiento"). El motivo para esos resultados
extraos o errores es que si a = 0 implica que e = 0 y al encontrarnos con una operacin del
tipo (-b + Sqr(d)) / edonde el denominador vale cero... operacin matemtica no permitida!
Esto ocurrir mientras no preparemos el programa para detectar este tipo de situaciones y darles
un tratamiento adecuado, cosa que veremos ms adelante.
Estamos construyendo programas sencillos que en lneas generales responden bien cuando se
dan las circunstancias previstas pero que fallan ante situaciones extraas. Esto no debe
preocuparnos por el momento, ya que a medida que progresemos como programadores iremos
construyendo programas cada vez ms slidos.
Aspecto grfico:
EJEMPLOS CON IF THEN ELSE EN VISUAL BASIC: PARADOJA DEL SI BURLADO POR UN
INTERVALO
Si bien podra esperarse obtener el mismo resultado con ambos cdigos, al ejecutar el cdigo 1
obtenemos como resultado que se muestre en pantalla "Arabia", mientras que al ejecutar el
cdigo 2 se muestra "Eusebio". La razn: Visual Basic no admite comparaciones dobles del tipo x
< y < z. Ante este tipo de escritura, slo es evaluada la primera condicin de las dos
pretendidas. Solucin? No usar comparaciones dobles.