« Curso de Algoritmos Informáticos y Borland C++ » BORLAND C++
Introducción El lenguaje “C” fue desarrollado en 1972 por Dennis Ritchie. Inicialmente el lenguaje se relaciono con el sistema operativo UNIX, ya que de la 13,000 líneas de código que lo componen, sólo unas 800 están escritas en lenguaje ensamblador y el resto, un 93%, están escritas en C. Es un lenguaje de nivel medio, ya que reúne características de alto nivel, las cuales combina con elementos del lenguaje ensamblador, lo que no significa que sea menos evolucionado que un lenguaje de alto nivel, ni que su uso sea más complicado. Dado que el lenguaje C está cercano al bajo nivel, el código producido es muy rápido y compacto. Gracias a todas sus propiedades, C es considerado como un lenguaje de propósito general. Por esto no sólo el sistema operativo UNIX y sus aplicaciones se escriben en él, sino una gran cantidad de aplicaciones de gran importancia como el sistema operativo MS-DOS.
CARACTERÍSTICAS PRINCIPALES DE C 1. 2. 3. 4. 5.
Flexible Portable de 90 a 95% De propósito general Permite crear software especial , tal como sistemas operativos Es compatible con sistemas operativos como Unix y DOS
REQUERIMIENTOS Memoria RAM de 512 Kb o 640 Kb, disco duro o dos unidades de disco flexible, un compilador, un Editor de Texto (cualquiera)
TÉRMINOS BÁSICOS EN BORLAND C++ Los términos que se describen a continuación serán en utilizados a lo largo del presente curso:
CÓDIGO FUENTE: Es el texto de programa que el usuario realiza.
CÓDIGO OBJETO: Es el programa traducido al lenguaje máquina.
COMPILADOR : Es el encargado de traducir el código fuentes en código objeto, de esta manera la ejecución de los programas programas es más rápida que la que se realiza a través de los lenguajes l enguajes interpretados. interpretados.
INTERPRETE : Es el que lee el código fuente de un programa línea a línea realizando las instrucciones contenidas en esa línea; cuando se desea correr un programa eb forma interpretada el código fuente debe estar siempre presente.
TIEMPO DE COMPILACIÓN COMPILACIÓN: Es el tiempo durante el cual el compilador traduce a lenguajes de máquina el código fuente, durante este período suelen detectarse los diferentes tipos de errores de compilación (sintácticos (sintácticos y léxicos).
TIEMPO DE EJECUCIÓN : Es el tiempo en que se ejecuta el programa.
ING. JUAN JOSÉ DEL ANGEL GARCÍA
PÁGINA 1 DE 25
« Curso de Algoritmos Informáticos y Borland C++ » ESTRUCTURA GENERAL DE UN PROGRAMA EN C++ Un programa en C++ está compuesto por un conjunto de funciones. La función principal se denomina MAIN y es la primera que se llama cuando el programa se ejecuta invocando después las otras funciones del programa.
Inclusión de librerías #include librerias
Definición de constantes #define constantes
Declaraciones globales
Variables funciones
Función principal main main() { declaraciones locales sentencias }
Definiciones de otras funciones Func1(....) { sentencias } Func1(....) { sentencias } .
REGLAS DE ÁMBITO SINTÁCTICO 1. Todo programa debe estar escrito en minúsculas. 2. Al finalizar las escritura escritura de cada cada sentencia se debe colocar colocar el carácter carácter punto y coma coma (;). 3. Toda función debe llevar paréntesis y no debe terminar con punto y coma, salvo cuando es invocada en el programa principal. 4. Toda instrucción compuesta en C++ debe ir encerrada entre llaves { }.
ING. JUAN JOSÉ DEL ANGEL GARCÍA
PÁGINA 2 DE 25
« Curso de Algoritmos Informáticos y Borland C++ » DESCRIPCIÓN DE LA ESTRUCTURA DE UN PROGRAMA
INCLUSIÓN DE LIBRERÍAS Un programa en C++ contendrá una serie de directivas #include que permiten incluir librerías en el programa. Entiéndase por librería a un archivo archivo con extensión H que activa activa y permite la utilización de ciertos comandos comandos en un lenguaje de programación. A diferencia del BASIC y el PASCAL, no existe en Borland C++ ninguna palabra reservada para la entrada entrada y salida como read y write, o INPUT y PRINT. No obstante, proporciona un conjunto de librerías donde se definen las funciones (como printf) para realizar estas operaciones. La sintaxis para incluir librerías es la siguiente: #include Las librerías que utilizaremos en el presente curso de C++ serán:
#include Permite incluir la librería estándar de entrada y salida, la cual permite al usuario utilizar los comandos de entrada y salida de información a un programa (printf, scanf).
#include Permite incluir la librería de monitor, la cual permite utilizar los comandos que realizan acciones sobre el monitor, tales como limpiar pantalla, cambiar colores a la pantalla y localizar información en la pantalla (clrscr, textcolor, textbackground y gotoxy).
#include Incluye la librería que permiten utilizar las funciones de cadena que realizan acciones como: comparar cadenas cadenas de caracteres y almacenar un valor dentro de una variable de tipo carácter (strcmp y strcpy).
#include Incluye la que permite utilizar la funciones matemáticas como: seno, coseno, tangente, logaritmo, etc.
DEFINICIÓN DE CONSTANTES CONSTANTES Un programa en C++ permite definir constantes por medio de la directiva #define. Entiéndase por constante a un identificar cuyo valor no cambia nunca durante la ejecución de un programa. Sintaxis: #define nombre valor_constante; Ejemplo: #define PI 3.1416 En el ejemplo se define una constante llamada PI a la cual se le asigna un valor de 3.1416
ING. JUAN JOSÉ DEL ANGEL GARCÍA
PÁGINA 3 DE 25
« Curso de Algoritmos Informáticos y Borland C++ » DECLARACIONES GLOBALES
VARIABLES Una variable es un identificador cuyo valor puede cambiar durante la ejecución de un programa. Cuando se declara una variable también es posible determinar el tipo de valor que puede almacenar dentro de sí. Cuando se almacena información en una variable en realidad se esta almacenando dicha información en la memoria RAM de nuestra nuestra computadora. La memoria de una computadora está compuesta por un un conjunto de de celdas de memoria que almacenan la información en forma temporal mientras el equipo está encendido. Cada celda de memoria memoria tiene asignada una dirección dirección de celda y una variable no es más que una forma más rápida y efectiva de encontrar la información información almacenada dentro dentro de las la s celdas, ya que un nombre de variable no es más que un nombre que se le asigna a una celda de memoria que almacena un dato en particular. En resumen, las variables son posiciones de memoria identificadas con un nombre único, cuya función es almacenar información que pueden cambiar su valor durante la ejecución de un programa en la memoria principal de la computadora.
ELEMENTOS DE UNA VARIABLE En resumen los elementos que forman a una variables son: Nombre de la variable Dirección de memoria Tipo de variable Valor asignado asignado a la variable
Nombre de la
Sueldo
variable
Tipo de variable Real o Float
180.50
Dirección de memoria
0865
Información
REGLAS PARA DAR NOMBRE A UNA VARIABLE Para dar un nombre a una variable o a cualquier identificador se deben tomar en cuenta las siguientes reglas: 1. Debe comenzar con un carácter alfabético, no puede comenzar con un dígito. 2. Puede contener solo letras y números, no se permiten espacios en blanco, letras acentuadas o cualquier otro símbolo. 3. Se puede utilizar el carácter de subrayado intermedio. 4. No se puede utilizar como identificador ninguna palabra reservada o nombre de función definida anteriormente. Un identificador puede ser: una variable, una constantes, un arreglo, una función, etc. y las reglas para dar nombre a un identificador son las siguientes:
ING. JUAN JOSÉ DEL ANGEL GARCÍA
PÁGINA 4 DE 25
« Curso de Algoritmos Informáticos y Borland C++ »
DEFINICIÓN O DECLARACIÓN DE VARIABLES Los identificadores que no forman parte del lenguaje deben ser definidos o declarados antes de poder utilizarse. Definir una variable es darle un nombre a una localización de almacenamiento (celda de memoria Ram). Las variables de definen colocando el tipo de datos seguido del nombre de la variable. Sintaxis: Tipo lista_de_variables;
TIPOS DE VARIABLES En Borland C++, todas las variables que se definen deben pertenecer a una categoría o tipo particular. A continuación continuación se presentan los tipo básicos que existen en este lenguaje: 1. 2. 3. 4. 5.
Char: se utiliza para almacenar un carácter o una cadena de caracteres. Int: Números enteros normales. Long: Números enteros largos. Float: Números reales o de punto flotante de precisión simple. Double: Números reales o de punto flotante de precisión doble.
VARIABLES DE TIPO CARACTER CARACTER El tipo de datos CHAR se utiliza para representar un carácter o un cadena de caracteres. Los caracteres están representados por el número que le corresponde según la tabla ASCII, es decir de un valor entre 0 y 255. Por lo tanto es lo mismo hablar del carácter ‘A’ que del número 65. Como los caracteres están enumerados según la tabla ASCII, se garantiza que están ordenados de la A a la Z, de forma tal que ‘A’ es menos que ‘B’, ‘B’ es menor que ‘C’, etc. De la misma forma forma están ordenados los caracteres en minúsculas y los dígitos del ‘0’ al ‘9’. Cuando desee hacer referencia a un solo carácter, ya sea para asignarle asignarle una valor a una variable o para establecer una condición; el carácter debe ir encerrado entre apóstrofes. Por ejemplo ‘A’, ‘a’, ‘O’, etc. Sin embargo, si desea hacer referencia a una cadena de caracteres (más de 1 carácter), la cadena se delimita entre comillas (“). Por ejemplo “VHS”, “BASE”, “MEXICO”, etc.
DECLARACIÓN DE VARIABLES DE TIPO CARACTER Una variable de tipo char a la que no se le indica la longitud, almacena solamente 1 carácter. Mientras que una variable char a la que se le indica la longitud almacena una cadena de caracteres del tamaño especificado. Char res, casado, estudiante; Char cliente[30], producto[25];
VARIABLES DE TIPO NUMÉRICO NUMÉRICO A continuación continuación se presentan los rangos de valores valores que se utilizan los los diferentes tipos tipos de variables numéricas numéricas del lenguaje:
Tipo de número Int Long Float Double
Rango de valores Entre – Entre –32,768 32,768 y +32767 Entre – Entre –2,147,483,648 2,147,483,648 y +2,147,483,647 Entre 1.7E+38 con una precisión de 7 dígitos. Entre 1.5E+308 con una precisión de 15 dígitos.
ING. JUAN JOSÉ DEL ANGEL GARCÍA
PÁGINA 5 DE 25
« Curso de Algoritmos Informáticos y Borland C++ »
DECLARACIÓN DE VARIABLES VARIABLES NUMÉRICAS NUMÉRICAS Int edad, nprod; Long existencia, prodven; Float sueldo, venta, prom; Double vtamax, vtamin;
NOTA: Todas las variables que se incluyan en un programa en C++ deben haber sido declaradas antes de utilizarlas. INICIALIZACIÓN DE VARIABLES VARIABLES Las variables se pueden inicializar inicializar a la vez que se declaran, declaran, o bien, inicializarse después de la declaración. El primer método: Char respuesta = ’S’; Char producto=”Camisa” Int contador = 1; Int edad = 20; Float peso = 87.20; El segundo método: Char contador; Contador=1; Int ventas; Ventas = 0;
ALCANCE DE UNA VARIABLE A las variables que se definen antes de la función main(), main(), se les llama variables globales y se les conoce de esta manera porque pueden ser utilizadas en cualquier función que forme parte del programa. A las variables que se definen dentro de cualquier función, se les conoce como variables locales, y sólo se pueden utilizar dentro de la función en que fueron declaradas.
ING. JUAN JOSÉ DEL ANGEL GARCÍA
PÁGINA 6 DE 25
« Curso de Algoritmos Informáticos y Borland C++ »
DECLARACIÓN DE FUNCIONES Un programa en C++ se compone de una o más funciones, las cuales deben ser declaradas antes de que pueda ser utilizada. Una función es un grupo de instrucciones que realizan una o más acciones.
LA FUNCIÓN MAIN La función main es una función privilegiada dentro del lenguaje C. Se puede decir que ejecutar un programa en C es ejecutar la función main, ya que lo primero que hace todo programa es invocar esta función. Si en el momento de compilar el programa no se encuentra su definición dentro del código, el compilador muestra un mensaje de error indicando la falta de la misma. Para definir un bloque de instrucciones se utilizan los símbolos de abrir y cerrar llaves (‘{‘ y ‘}’) de la misma forma en que se utilizan las palabras begin y end en pascal.
SENTENCIAS COMPUESTAS COMPUESTAS Una sentencia compuesta consiste de una secuencia de instrucciones (2 o más) delimitadas por los símbolos ‘{‘ y ‘}’. El cuerpo del programa principal está constituido por una sentencia compuesta, debido a que contiene más de 2 instrucciones y muchas de las estructuras soportadas por C también utilizan sentencias compuestas. Al principio principio de toda sentencia sentencia compuesta compuesta se pueden declarar el conjunto conjunto de variables que serán utilizadas utilizadas dentro del bloque: { declaraciones de variables; sentencias del bloque }
SECUENCIAS DE ESCAPE ES CAPE Borland C++ proporciona una cantidad de símbolos especiales denominados secuencias de escape, que se pueden utilizar dentro de cualquier texto para controlar su presentación en pantalla. Las principales secuencias de escape son las siguientes:
Secuencia de escape \a \b \n \t \v
ING. JUAN JOSÉ DEL ANGEL GARCÍA
Carácter que representa Carácter de alarma (campana) Retroceso Nueva línea Tabulador horizontal Tabulador vertical
PÁGINA 7 DE 25
« Curso de Algoritmos Informáticos y Borland C++ » COMANDOS DE ENTRADA Y SALIDA DE DATOS
FUNCIÓN PRINTF Esta función permite la escritura de información de salida en la pantalla. El usuario puede imprimir tanto mensajes, como el contenido de las variables. La sintaxis está función es la siguiente: Printf (“Cadena de control:”,lista de argumentos); La cadena de control puede contener tanto mensajes como códigos de formato y la lista de argumentos contiene las variables cuyo contenido contenido se visualizará en la pantalla. Ejemplo 1 de printf : #include #include main() { clrscr(); printf(“\t\t printf(“ \t\t Este es \ n”); n”); printf(“\t\t printf(“ \t\t mi primer \ n”); n”); printf(“\t\ printf(“ \t\ t en Borland C++.”); getch(); }
CÓDIGOS DE FORMATO Los códigos de formato se utilizan para permitir la entrada (lectura) y salida (escritura) de los diferentes tipos de variables que existen en el código de un programa.
Códigos de formato %d %i %f %c %s %o %x
Tipo de variable que lee o escribe Número entero. Decimal Número de punto o coma flotante (con decimales) Un solo carácter. Una cadena de caracteres (2 o más caracteres) Octal Hexadecimal
CLRSCR() Limpia el contenido contenido de la pantalla. Requiere Requiere la librería conioh GETCH() Lee un carácter del teclado sin visualizarlo en pantalla. Generalmente se utiliza para hacer una pausa en la ejecución del programa, programa, espera a que se pulse una tecla.
Requiere la librería stdio.h
FFLUSH(STDIN) Limpia el buffer de almacenamiento, solo para variables de tipo Char.
ING. JUAN JOSÉ DEL ANGEL GARCÍA
PÁGINA 8 DE 25
« Curso de Algoritmos Informáticos y Borland C++ »
OPERADORES ARITMÉTICOS ARITMÉTICOS Los operadores aritméticos se utilizan para crear expresiones expresiones matemáticas:
Operador + * / %
Operación Suma Resta Multiplicación División Modulo
Ejemplo
Resultado
4+3 5-2 5*2 5/3 22 % 5
7 3 10 1.66666 2
El símbolo % permite obtener el residuo de una división, es válido unicamente para datos de tipo entero.
ASIGNACIONES Y EXPRESIONES EXPRESIONES El signo utilizado para asignar un valor a una variable es el igual (=). Las variables almacenan el valor que se expresa del lado derecho de la asignación. La forma general de la sentencia de asignación es la siguiente: NomVar=Valor; Ejemplo: Sum=0; Venta=300; Venta=300; Donde NomVar es el nombre de una variable que ha sido previamente declarada y el valor es cualquier expresión numérica, lógica o de carácter. Cuando se asigna una expresión a una variable, primero se resuelve la expresión y después se almacena el resultado en la variable asignada. asignada. b=5 h=6 a = (b*h)/2 Antes de hacer una sentencia de asignación asignación con otras variables, estas debe contener un valor previo, de lo contrario ocurrirá un error.
CUAL ES LA DIFERENCIA ENTRE UTILIZAR = O == El signo de igual (=) se utiliza para asignar valores a una variable, mientras que el signo doble igual (==) se utiliza para establecer una comparación lógica entre dos valores. A = B A == B
ING. JUAN JOSÉ DEL ANGEL GARCÍA
Asignación Comparación
PÁGINA 9 DE 25
« Curso de Algoritmos Informáticos y Borland C++ »
PRIORIDAD DE LOS OPERADORES Una computadora resuelve las expresiones tomando en cuenta la jerarquía, prioridad o grado de importancia que poseen los operadores aritméticos. Los operadores que tiene mayor prioridad sobre otros se realizan primero.
Operador
Operación
Prioridad
() ++,-*, / , % +,=,+=,-=,*=,/=,%=
Agrupación. Agrupación. Incremento, Decremento. Multiplicación, División, Modulo. Suma, Resta. Operadores de asignación.
1 2 3 4 5
Ejemplo 2 de printf: #include #include float area; int b=5,h=6; main() { clrscr(); area=(b*h)/2; printf(“El área del triángulo de base %d \ n”,b); n”,b); printf(“y altura de %d es %f”,h,area); getch(); }
IMPRESIÓN DE NÚMEROS REALES Al igual que es Pascal, cuando cuando se imprimen números números reales, el número se muestra muestra sin formato y con un un número muy grande de decimales. Se puede cambiar la forma en que se visualiza colocando dos números después del símbolo de % y antes del tipo (d, f, s o c), separados por un punto. El primer número especifica el ancho total de caracteres y el segundo el número de decimales que se utilizan. A continuación continuación veremos veremos algunos ejemplos ejemplos considerando considerando los los siguiente: Float num=8.5125;
Ejemplos Printf(“%f”,num) Printf(“%6.2f”,num) Printf (“%.2f”,num) (“%.2f”,num) Printf(“%6.0f”,num)
ING. JUAN JOSÉ DEL ANGEL GARCÍA
Resultado 8.512500 8.51 8.51 9
PÁGINA 10 DE 25
« Curso de Algoritmos Informáticos y Borland C++ »
FUNCIÓN SCANF Esta función permite la entrada de datos a un programa a través del teclado. La función lee los datos y los almacena en las variables indicadas. No es posible incluir mensajes dentro de la misma orden scanf. Por lo tanto, todos los mensajes de entrada deben hacerse antes del scanf. Para utilizar este comando es necesario conocer los códigos de formato para los diferentes tipos de variables de C++. La sintaxis sintaxis que utiliza scanf es la siguiente: Scanf(“%códigos de formato”,&variable) El símbolo & (ampersand), (ampersand), se utiliza para almacenar el dato introducido introducido por el usuario a través del teclado teclado dentro de una variable. Ejemplos: Scanf(“%s”,&nom)
Pide una cadena de caracteres que se almacena dentro de la variable nom de tipo carácter.
Scanf(“%f”,&sueldo)
Pide un número con decimales que se almacena dentro de la variable sueldo de tipo flotante.
También es posible utilizar múltiples argumentos dentro de una misma función scanf, como en el siguiente ejemplo: Printf(“Introduzca el valor de a y b:”); scanf(“%d %d”,&a, &b); el usuario debe separar los valores con espacio o tabulación. Si introduce solamente un valor, el programa se queda esperando hasta que se coloque el valor faltante.
EL MANEJO DE CADENAS CON ESPACIOS EN SCANF %s
: Lee una cadena de caracteres eliminado todos aquellos que se encuentren encuentren después del primer espacio en blanco.
%[^\n] : Lee todos los caracteres de una cadena hasta el fin de la línea, sin importar si incluye espacios en blanco.
Ejemplos: Printf(“Digite su nombre: “); scanf(“%s”,&nom); Printf(“Digite su nombre: “); scanf(“%[^ scanf(“%[^\ \ n]”,&nom); n]”,&nom);
ING. JUAN JOSÉ DEL ANGEL GARCÍA
PÁGINA 11 DE 25
« Curso de Algoritmos Informáticos y Borland C++ »
ÁREA DE UN TRIÁNGULO TRIÁNGULO #include #include float area; int bas,alt; main() { clrscr(); printf(“Introduzca printf(“Int roduzca la base : “); scanf(“%d”,&bas); printf(“Introduzca printf(“Introduzca la altura: “); scanf(“%d”,&alt); scanf(“%d”,&alt); area=(bas*alt)/2; printf(“El área del triángulo triángulo es %6.1f”,area); %6.1f”,area); getch(); }
CALCULO DE VIDA #include #include char nom; int edad; float dia,hrs.min,seg; main() { clrscr(); gotoxy(15,6); printf(“Introduzca su noombre : “); “); scanf(“%[^\ scanf(“%[^\ n]”,&nom); n]”,&nom); gotoxy(15,8); printf(“Introduzca su edad : “); scanf(“%d”,&edad); dia=edad*365; hrs=dia*24; min=hrs*60; seg=min*60; gotoxy(15,10); printf(“Su edad equivale a:”); gotoxy(15,12); printf(“%10.1f dias.”,dia); gotoxy(15,13); printf(“%10.1f horas.”,hrs); gotoxy(15,14); printf(“%10.1f minutos.”,min); gotoxy(15,15); printf(“%10.1f segundos.”,seg); getch(); }
ING. JUAN JOSÉ DEL ANGEL GARCÍA
PÁGINA 12 DE 25
« Curso de Algoritmos Informáticos y Borland C++ »
OPERADORES ARITMÉTICOS COMBINADOS En el lenguaje Borland C++ también se encuentran un conjunto de asignaciones que son poco convencionales, pero muy útiles. Estas asignaciones mezclan una operación con la asignación. Por ejemplo: a + = 5; lo cual significa que se debe sumar 5 a la variable a. Esta asignación es equivalente a la siguiente: a = a + 5; Se puede utilizar cualquier operación matemática en el lugar del signo de adición (+). A continuación se muestran algunos ejemplos de estas asignaciones y su forma equivalente:
Operador
Sentencia Abreviada
+= -= *= /= %=
M += N M -= N M *= N M /= N M %= N
Sentencia No abreviada M=M+N M=M-N M=M*N M =M / N M=M%N
OPERADORES DE INCREMENTO Y DECREMENTO DECREMENTO Además existen los operadores operadores de incremento incremento y decremento decremento que permiten permiten sumar o restar la unidad a la variable variable asignada.
Operador
Sentencia Abreviada
++ --
C++; C--;
Sentencia No abreviada C = C + 1; C = C – C – 1; 1;
Estos operadores se pueden utilizar en forma prefija o postfija:
EJEMPLO DE FORMA PREFIJA Int a =1, b; b = a++;
/* b vale 1 y a vale 2 */
esto equivale a: Int a =1, b; b = a; a = a + 1;
/* b vale 1 */ /* a vale 2 */
esto equivale a: Int a =1, b; a = a + 1; b = a;
/* a vale 2 */ /* b vale 2 */
EJEMPLO DE FORMA POSTFIJA Int a =1, b; b = ++a;
/* b vale 2 y a vale 2 */
ING. JUAN JOSÉ DEL ANGEL GARCÍA
PÁGINA 13 DE 25
« Curso de Algoritmos Informáticos y Borland C++ »
CONTADORES Un contador permite incrementar o decrementar el valor de una variable en una cantidad constante. Sintaxis: Variable = variable variable + constante; constante; Ejemplos: A+=1; que equivale equivale a A = A + 1; C+=5; que equivale equival e a C = C + 5; B-=1; que equivale equival e a B = B - 1; D-=3; que equivale equival e a D = D - 3;
ACUMULADORES ACUMULADORES Un acumulador es una variable que incrementa su valor de una variable en cantidades variable. Generalmente se utiliza para acumular o sumar valores numéricos numéricos tales como: ventas, compras, calificaciones, calificaciones, etc. Sintaxis: Variable1 = Variable1 Variable1 + Variable2; Variable2; Ejemplos: TOTAL+=VTA; que equivale equival e a TOTAL= TOTAL+VTA; SUM+=PROM; que equivale equival e a SUM=SUM+PRO,M;
CONDICIONES En algunos programas, es necesario establecer condiciones que determinan el camino que tomara el flujo del programa. Las condiciones no son más que comparaciones entre dos valores (2 números, 2 variables, 1 número y una variable, vari able, etc) utilizando operadores relacionales relacionales y lógicos.
OPERADORES RELACIÓNALES RELACIÓNALES Los operadores que se utilizan para establecer condiciones son los operadores relacionales o de relación. Las condiciones devuelven como resultado un valor verdadero (un valor distinto de cero) o falso (el número cero).
Operador == ¡=, #, <> > < >= <=
Significado Igual a Diferente a Mayor que Menor que Mayor o igual que Menor o igual que
Ejemplo A == B A ¡= B A > B A < B A >= B A <=B
Los operadores relacionales tienen menor prioridad que los operadores operadores aritméticos, y asociatividad de izquierda a derecha. M + 5 <= 2 * N equivale a (M + 5) <= (2 (2 * N) A continuación continuación se presentan presentan algunos ejemplos ejemplos de condic condiciones. iones. Res==’S’; ‘Z’ >= ‘A’
ING. JUAN JOSÉ DEL ANGEL GARCÍA
Precio > 2000 Num1 >= Num2
PÁGINA 14 DE 25
« Curso de Algoritmos Informáticos y Borland C++ »
OPERADORES LÓGICOS En ocasiones es necesario realizar comparaciones compuestas en los programas, en las cuales hay que hacer 2 o más condiciones. Los operadores lógicos se utilizan para enlazar varias expresiones lógicas (condiciones) en una sola, dando como respuesta valores BOOLEANOS, ya sea verdadero o falso.
Operador Lógico
Expresión Lógica
Significado
&&
Op1 && Op2
Y , la condición es verdadera solo cuando ambos operandos son verdaderos.
||
Op1 || Op2
O, la condición es verdadera cuando alguno de los dos operandos es verdadero.
!
NO, se le llama negación y en esta la condición es
!Op
verdadera cuando el operando es falso. Ejemplos: vtas>=2000 && vtas<=2000 res==’s’ || res==’S” !sueldo<2000
TABLA DE VERDAD Y Op1 Op2 Verdadero Verdadero Falso Falso
Verdadero Falso Verdadero Falso
Op1 && Op2 Verdadero Falso Falso Falso
TABLA DE VERDAD O Op1 Op2 Verdadero Verdadero Falso Falso
Verdadero Falso Verdadero Falso
Op1 || Op2 Verdadero Verdadero Verdadero Falso
TABLA DE VERDAD NO Operando !Operando Verdadero Falso
Falso Verdadero
USO DE LOS COMENTARIOS Los comentarios son líneas que o se ejecutan dentro de un programa y que tienen por función explicar información contenida dentro del mismo, o bien, indicar el principio o fin de un bloque de ordenes en particular. Los comentarios que se encierran encierran entre símbolos ‘/*’ y ‘*/’ pueden colocarse en cualquier parte del programa y pueden extenderse en más de una línea. Mientras que el símbolo ‘//’ se utiliza para agregar a un programa comentarios de una sola línea. lí nea.
ING. JUAN JOSÉ DEL ANGEL GARCÍA
PÁGINA 15 DE 25
« Curso de Algoritmos Informáticos y Borland C++ » MEJORANDO LA PRESENTACIÓN DEL PROGRAMA
LOCALIZACIÓN DE INFORMACIÓN La instrucción gotoxy, permite localizar información de salida en la pantalla. Sintaxis: Gotoxy(columna, fila); Ejemplos: Gotoxy(10,5); printf(“Bienvenido printf(“Bie nvenido al Sistema”); Gotoxy(15,7); printf(“Cliente:”); scanf(“%s”,&clie); scanf(“%s”,&clie);
CAMBIOS DE COLOR La instrucción textbackground permiten cambiar el color del fondo de la pantalla, mientras que la instrucción textcolor permite cambiar el color de primer plano del texto visualizado. Sintaxis: Textbackground(código de color); Textcolor(código de color);
CÓDIGOS DE COLOR
COLOR
CÓDIGO NUMERO
CÓDIGO TEXTO
Negro Azul Verde Cyan Rojo Magenta Café Gris Claro Gris Oscuro Azul Claro Verde Claro Cyan Claro Rojo Claro Magenta Claro Amarillo Blanco Parpadenate
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 128
BLACK BLUE GREEN CYAN RED MAGENTA BROWN LIGHTGRAY DARKGRAY LIGHTBLUE LIGHTGREEN LIGHTCYAN LIGHTRED LIGHTMAGENTA YELLOW WHITE BLINK
ESTRUCTURAS DE CONTROL BORLAND C++ contiene las siguientes estructuras de control.
Selectivas
If, if-else Switch
Repetitivas
While Do-while For
Bifurcación de control
ING. JUAN JOSÉ DEL ANGEL GARCÍA
Break, Continue Goto Return Exit
PÁGINA 16 DE 25
« Curso de Algoritmos Informáticos y Borland C++ » ESTRUCTURAS DE CONTROL SELECTIVAS
SENTENCIA IF (SI - ENTONCES) La sentencia IF evalúa una condición y ejecuta un bloque de ordenes en caso de que sea verdadera. Si el bloque de ordenes esta formado por más de una instrucción, debe ir encerrado entre llaves ‘{‘ y ‘}’. Sintaxis simple: If (condición) Instrucción;
Sintaxis compuesta: compuesta: If (condición) { bloque de sentencias; }
Ejemplos: If (venta>=2000) Descto=subto*0.10;
If (semestre==1) { inscripcion=150; mensualidad=110; }
SENTENCIA IF – ELSE (SI – ENTONCES – SINO)
La sentencia IF evalúa una condición y ejecuta un bloque de ordenes que se encuentra después del if si la condición es verdadera y ejecuta el bloque de ordenes después del else si la condición es falsa. Si el bloque de ordenes esta formado por más de una instrucción, debe ir encerrado entre llaves ‘{‘ y ‘}’. El sangrado (espacio al principio de las líneas) es opcional aunque se recomienda utilizarlo, ya que facilita la lectura del código. código. Sintaxis simple: If (condición) Instrucción; Else Instrucción;
Sintaxis compuesta: compuesta: If (condición) { bloque de sentencias; } else { bloque de sentencias; }
Ejemplos: If (venta>=2000) Descto=subto*0.10; Else Descto=subt*0.05;
ING. JUAN JOSÉ DEL ANGEL GARCÍA
If (semestre==1) { inscripcion=150; mensualidad=110; } else { inscripcion=120; mensualidad=90; }
PÁGINA 17 DE 25
« Curso de Algoritmos Informáticos y Borland C++ »
COMPARACIONES COMPARACIONES CON CADENAS DE CARACTERES Si desea establecer comparaciones entre cadenas de caracteres debe utilizar la función strcmp (string compare). Esta función compara dos cadenas y devuelve un número entero con un valor. Menor que cero (< 0) Igual a cero (=0) Mayor que cero (>0) Sintaxis:
si si si
cadena1cadena2
Strcmp(variable,”cad Strcmp(variable,”cadena ena de caracteres”)
Ejemplos: If (strcmp(contrato,”BASE”)=0) Comisión=sueldo*0.20; Else Comisión=sueldo*0.10;
If (strcmp(fmto,”DVD”)=0) Renta=40; Else Renta=25;
ASIGNACIÓN DE UN VALOR A UNA VARIABLE VARIABLE DE TIPO CARÁCTER CARÁCTER Si desea asignar un valor a una variable de tipo carácter no es posible hacerlo de la misma manera en que se asigna un valor a una variable de tipo numérico, en la cual la asignación es directa por ,medio del signo de igual (edad=20). Para asignar una valor a una variable de tipo carácter debe utilizar la función strcpy (string copy), la cual copia la cadena indicada indicada dentro de la variable de tipo carácter. carácter. Sintaxis: Strcpy(variable de tipo carácter,“cadena”) Ejemplo: If (edad<1) Strcpy(area Strcpy(area ,“Lactantes”); Else Strcpy(area, Strcpy(area, “Maternal”);
IF ANIDADOS (UN IF DENTRO DE OTRO IF) El termino anidamiento significa uno dentro de otro y este caso al hablar de if anidados, nos estamos refiriendo a la colocación de un if dentro de otro if. No existe una sintaxis general para los if anidados debido a que puede tomar diferentes formas según lo requiera el programa. Sin embargo, a continuación daremos un ejemplo: If (condición1) { if (condición2) instrucción; else instrucción; } else { if (condición3) instrucción; else instrucción; }
ING. JUAN JOSÉ DEL ANGEL GARCÍA
PÁGINA 18 DE 25
« Curso de Algoritmos Informáticos y Borland C++ »
SENTENCIA SWITCH
La sentencia switch se utiliza para la creación de programas de menús o de selección múltiple. La sentencia switch permite hacer múltiples comparaciones con respecto a una misma variable o expresión. La sentencia switch proporciona un método compacto para realizar este tipo de comparaciones, sin necesidad de utilizar múltiples múltiples sentencias condicionales. condicionales. El termino menú se utiliza para aquellos programas en los que se muestran un conjunto de opciones, de entre las cuales, el el usuario selecciona selecciona aquella aquella que desee desee ejecutar. ejecutar. De la misma manera manera en la que un cliente de un restaurant, puede seleccionar el platillo platillo que desea pedir seleccionándolo seleccionándolo de la carta carta o menú del establecimiento que muestra varios platillos. Su sintaxis es: Switch(variable) { case constante 1: sentencias; break; case constante 2: sentencias; break; ...... case constante n: sentencias; break; default: sentencias; break; } donde el resultado de la expresión debe ser entero y los valores deben ser constantes enteras. La sentencia switch evalúa la expresión que se encuentra entre paréntesis. El valor obtenido se compara con cada una de las constantes especificadas en las listas de constantes, constante 1, constante 2 y constante n y cuando se halla una correspondencia (los valores valore s son iguales), se ejecutan las sentencias que se encuentren a continuación de los dos puntos (inclusive las de los demás casos) hasta que se encuentren la sentencia break . Si no se obtiene ninguna correspondencia con las constantes, se ejecutan las sentencias que se encuentran después de la palabra default.
ING. JUAN JOSÉ DEL ANGEL GARCÍA
PÁGINA 19 DE 25
« Curso de Algoritmos Informáticos y Borland C++ » SENTENCIAS REPETITIVAS Las sentencias repetitivas permiten la generación de ciclos o bucles en los cuales las instrucciones contenidas dentro del ciclo se repiten un determinado número de veces o iteraciones. iteraciones . Un ciclo es la repetición de una o más sentencias varias veces, donde a cada repetición se le conoce como iteración. Entonces, una iteración es una sola repetición de un grupo de ordenes.
LA SENTENCIA WHILE (MIENTRAS-EJECUTAR) Esta sentencia ejecuta un conjunto sentencias mientras la condición es verdadera y sale del ciclo cuando la condición se hace falsa. En ese momento el flujo del programa pasa a la siguientes línea después del cierre del while. Siempre debe colocarse antes del while una sentencia que haga verdadera la condición y que permita al programa entrar al ciclo la primera vez. Sintaxis: While (condición) { sentencias; } Ejemplo: num=0; While (num<10) { num++; printf(“%d\ printf(“%d \ n”,num); n”,num); }
LA SENTENCIA DO – WHILE (ELECUTAR – MIENTRAS) Al igual que el ciclo while, este ciclo ejecuta un conjunto conjunto sentencias mientras la condición condición es verdadera y termina cuando la condición es falsa, pasando el flujo a la siguiente línea. Lo que hace diferente a esta sentencia del while, es que siempre se ejecuta por lo menos una vez debido a que la condición se evalúa al final y además no requiere al inicio una expresión que haga verdadera la condición. condición. Sintaxis: do { sentencias; } While (condición); Ejemplo: do { num++; printf(“%d\ printf(“%d \ n”,num); n”,num); } While (num<10):
ING. JUAN JOSÉ DEL ANGEL GARCÍA
PÁGINA 20 DE 25
« Curso de Algoritmos Informáticos y Borland C++ »
LA SENTENCIA FOR (PARA – HASTA) La sentencia for permite generar un ciclo en el cual se encuentran predefinido el número de iteraciones que lo forman, es decir, el número de veces que se repetirán las instrucciones (1 o más) que están contenidas dentro del bucle. En esta estructura se determina un valor inicial, una condición que se debe cumplir para que se ejecute el bucle for y por último un incremen i ncremento to con el cual se varía el valor inicial de la variable. Sintaxis: for (valor_inicial; condición; incremento) { sentencias; } Ejemplos: For (num=1; num<=10;num++) { printf(“%d\ printf(“%d \ n”,num); n”,num); }
For (num=10; num>=1;num--) { printf(“%d\ printf(“%d \ n”,num); n”,num); }
BIFURCACIONES DE CONTROL
LA SENTENCIA GOTO La sentencia goto transfiere o bifurca incondicionalmente el control del programa a la sentencia etiquetada por el identificador. Muchos programadores prefieren omitir su uso en códigos de programas por considerar que el utilizarlo permite hacer ek código del programa ilegible. Sin embargo, el uso moderado de esta instrucción permite agilizar la ejecución ejecución del programa. programa. La forma general de la instrucc i nstrucción ión goto es la siguiente: etiqueta: instrucción (es); goto etiqueta; Crear una etiqueta (label) consiste en determinar determinar un nombre que debe finalizar con el símbolo “:”, el cual será reconocido reconocido por el goto. Un ejemplo de esta instrucción es el siguiente. main( ) { x = 1; volver; x++; if (x!=10) goto volver; }
LA SENTENCIA BREAK Las sentencias break y continue continue se utilizan para cambiar la forma en que se ejecutan las sentencias sentencias repetitivas. La sentencia break tiene básicamente dos funciones dentro de C++. Si se encuentra una sentencia break en medio de un ciclo (while, do-while y for), el bucle se da por terminado inmediatamente y continua con la siguiente instrucción después del mismo. La sentencia break también se utiliza para terminar la ejecución de cada uno de los casos (case) de la sentencia switch-case.
ING. JUAN JOSÉ DEL ANGEL GARCÍA
PÁGINA 21 DE 25
« Curso de Algoritmos Informáticos y Borland C++ » Ejemplo: #include #include main( ) { clrscr( ); int x; for (x=1;x<100;x++) { printf(“%d\ printf(“%d \ n”,x); n”,x); if (t = = 10) break; } getch( ); }
LA SENTENCIA CONTINUE La sentencia continue, hace que se pase la ejecución a la siguiente iteración del bucle.
LA FUNCION EXIT La función exit sirve para dar por terminado el programa y obligar a retornar al sistema operativo.
NOTA: Un ciclo infinito se produce cuando los valores adquiridos por las variables dentro del bucle nunca satisfacen a la condición especificada. Por ejemplo: x=10; while (x>=1) { printf (“%d”,x); x++; }
ING. JUAN JOSÉ DEL ANGEL GARCÍA
PÁGINA 22 DE 25
« Curso de Algoritmos Informáticos y Borland C++ » ARRAYS (ARREGLOS) Un arreglo permite almacenar un conjunto de valores del mismo tipo dentro de una sola variable, lo cual se logra por medio de un índices y ciclos for.
ARREGLO UNIDIMENSIONAL O VECTOR Los arreglos unidimensionales son considerados como un conjunto de datos del mismo tipo que poseen un nombre determinado. determinado. Un vector se representa gráficamente gráficamente de la siguiente manera: NUM[0] NUM[1] NUM[2] NUM[3] NUM[4]
20 15 30 5 45
Las posiciones de un arreglo unidimensional son reconocidas por un índice que en realidad es un número entero que denota la posición dentro de un arreglo. La primera posición de un vector en C++ toma el valor 0, la siguiente valor 1 y así sucesivamente. Para hacer referencia a una posición de un arreglo en C++, se debe hacer referencia al nombre general del vector y después a su índice. Por ejemplo el primer elemento del arreglo datos se refiere: NUM[0]
COMO DECLARA UN ARREGLO UNIDIMENSIONAL UNIDIMENSIONAL Para declarar un arreglo unidimensional unidimensional se debe hacer de la siguiente manera: Especificador_de_tipo nombre_variable[tamaño]; El especificador_de_tipo, hace referencia al tipo de datos que tendrán los elementos del vector. El nombre_variable hace referencia al nombre general del vector, y el tamaño al número de elementos o posiciones del arreglo. Ejemplos:
Int edad[10];
Vector edad con 10 posiciones posiciones de tipo tipo número entero. entero.
Float sueldo[5];
Vector de 5 posiciones posiciones de de tipo número número real o con decimales. decimales.
Char cliente[7][20]; Vector de tipo carácter de 7 posiciones posiciones con un tamaño de 20 caracteres cada posición.
ING. JUAN JOSÉ DEL ANGEL GARCÍA
PÁGINA 23 DE 25
« Curso de Algoritmos Informáticos y Borland C++ »
COMO LLENAR UN ARREGLO UNIDIMENSIONAL Para llenar un arreglo unidimensional es necesario hacer uso de una sentencia repetitiva que permita acceder a todas las posiciones del vector, generalmente se utiliza el ciclo for para producir el cambio de índice en el vector. Ejemplo: #include #include int num[5],x; main( ) { clrscr( ); for (x=0;x<=4;x++) { gotoxy(20,7+x); scanf(“%d”,&num[x]); } getch( ); }
COMO IMPRIMIR UN ARREGLO UNIDIMENSIONAL Generalmente también se utiliza el ciclo for para generar el cambio de índice que permita imprimir todas las posiciones de un arreglo unidimensional que ha sido capturado previamente. Ejemplo: for (x=0;x<=4;x++) { gotoxy(40,7+x); printf(“%d”,num[x]); }
ARREGLO BIDIMENSIONAL O MATRIZ Los arreglos bidimensionales son los construidos en dos direcciones (filas y columnas), de tal manera que su índice está compuesto por dos partes donde la primera corresponde a la fila y la segunda a la columna. Una matriz se representa gráficamente gráficamente de la siguiente manera:
MATRIZ VENTAS DE 4X3 NUM[X][Y] 0 1 2
0
1
2
3
2
en donde, la posición VENTAS[2][1] de la matriz posee el valor de 15.
ING. JUAN JOSÉ DEL ANGEL GARCÍA
PÁGINA 24 DE 25
« Curso de Algoritmos Informáticos y Borland C++ »
COMO DECLARA UN ARREGLO BIDIMENSIONAL La declaración de arreglos bidimensionales es similar a la de arreglos unidimensionales, unidimensionales, pero en esta ocasión se define el número de filas y el número de columnas que tendrá el arreglo. Sintaxis: Especificador_de_tipo Especifica dor_de_tipo nombre_variable[tamaño nombre_variable [tamaño filas][tamaño filas][tama ño columnas]; Por ejemplo: Int ventas[4][3]; En el ejemplo anterior se define una matriz denominada ventas que posee 4 filas y 10 columnas.
COMO LLENAR E IMPRIMIR UNA MATRIZ Generalmente se utilizan dos ciclos for para para generar el cambio cambio de índice tanto tanto para las filas como para para las columnas y que permita llenar e imprimir todas las posiciones de un arreglo bidimensional. #include #include int ventas[4][3],x,y; main( ) { clrscr( ); for (x=0;x<=3;x++) { col=0; for (y=0;y<=2;y++) { gotoxy(10+col,7+x); scanf(“%d”,&ventas[x][y]); scanf(“%d”,&ventas[x][y]) ; col+=10; } } clrscr( ); for (x=0;x<=3;x++) { col=0; for (y=0;y<=2;y++) { gotoxy(10+col,7+x); printf(“%d”,ventas[x][y]); col+=10; } }
ING. JUAN JOSÉ DEL ANGEL GARCÍA
PÁGINA 25 DE 25