Practica5 Curso0809
Practica5 Curso0809
Practica5 Curso0809
PRCTICA 5. SENTENCIAS DE CONTROL REPETITIVAS. 1. Introduccin. En esta prctica veremos todos los conceptos explicados en la segunda parte del Tema 5 de teora: las Sentencias de Control Repetitivas, que permiten repetir un trozo de cdigo un nmero de veces determinadas. Estudiaremos los tres tipos de estructuras de control repetitivas o iterativas que ofrece el Lenguaje C: while, do-while y for.
2. Conceptos nuevos Los conceptos nuevos introducidos son: 1) Estructura y funcionamiento de las Sentencias de Control Repetitivas. 2) Uso de una variable como contador.
3. Lenguaje C Las nuevas caractersticas de C que ha aprendido y que necesita saber para la realizacin de esta prctica son: 1) Funcionamiento y Diagrama de Flujo de la Sentencia de Control while 2) Funcionamiento y Diagrama de Flujo de la Sentencia de Control do-while 3) Funcionamiento y Diagrama de Flujo de la Sentencia de Control for
4. Entorno DevC++. Para esta prctica 5 es totalmente imprescindible que sepa usted hacer el seguimiento y depuracin de un programa ejecutndolo paso a paso, utilizando para ello las herramientas que ofrece el EID DevC++ y que han sido comentadas en prcticas anteriores. Adems, sera conveniente que investigara y averiguara para qu sirven las siguientes opciones del DevC++: Depurar Depurar Depurar Aadir/Quitar Punto de Ruptura (Ctrl F5) Saltar Paso (Ctrl F7) Ir a cursor (Shift F4)
Estas opciones se vuelven realmente importantes cuando queremos ejecutar un programa paso a paso que contiene bucles, ya que nos facilitan enormemente nuestro trabajo. Descubra cmo funcionan probndolas directamente y pensando un poco, y acudiendo a los manuales, libros o tutoriales cuando sea necesario (recuerde que deben ser manuales donde se explique el entorno DevC++).
Fundamentos de Informtica Primero de Ingeniera Tcnica Industrial Mecnica, Qumica, Electricidad y Electrnica Departamento de Tecnologas de la Informacin
5. Qu sentencia de control repetitiva utilizar? A continuacin mostramos una breve comparativa de uso de los tres tipos de Sentencia de Control Repetitivas vistas (while, do-while y for), a fin de que entienda fcilmente en qu casos utilizar una u otra: for El uso ms frecuente de este tipo de bucles se produce cuando el nmero de repeticiones se conoce por anticipado y la condicin del bucle puede ser controlada por un contador. El uso ms frecuente se produce cuando la repeticin del bucle no est controlada por un contador sino por una cierta condicin (simple o compleja). El bucle puede que no se ejecute ninguna vez Se utiliza en las mismas condiciones que el while y cuando adems se debe asegurar que el bucle se ejecute al menos una vez. Ejemplo: men de opciones con filtro.
while
do-while
6. Tcnicas de prueba de un bucle. En general las tcnicas de pruebas son mtodos o tcnicas cuyo objetivo es determinar si un programa (o un trozo de cdigo) funciona correctamente. El objetivo final de una estrategia de prueba consiste en detectar errores. Existen distintos tipos o tcnicas de prueba. Nosotros nos centraremos en aquella que nos permite probar si un bucle est bien construido o no, esto es, averiguar mediante un nmero de pruebas si el bucle funciona correctamente. Sea N el nmero mximo de pasos permitidos o iteraciones que da un bucle. A la hora de comprobar formalmente si un bucle funciona correctamente, deberemos probarlo con los siguientes casos: a) b) c) d) e) f) g) Probar el bucle pasndolo por alto completamente. Pasar slo una vez por el bucle. Pasar dos veces por el bucle. Hacer que el bucle de m vueltas, siendo m<N Hacer que el bucle de N-1 vueltas Hacer que el bucle de N vueltas Intentar que el bucle de N+1 vueltas.
Como podr imaginar a veces no es necesario realizar todos los casos. Esto depender del tipo de bucle y de la condicin que tenga ese bucle. Lo que s es muy interesante que entienda es que los fallos en un bucle se suelen dar en la condicin de salida del mismo, y que esa condicin, que puede provocar que el bucle se ejecute una vez ms o una vez menos de lo que queremos que se ejecute, s es importante que sea muy bien analizada (aplicando los pasos e), f) y g) de los anteriormente propuestos).
Fundamentos de Informtica Primero de Ingeniera Tcnica Industrial Mecnica, Qumica, Electricidad y Electrnica Departamento de Tecnologas de la Informacin
7. Gua de estilos para escribir cdigo. A estas alturas de curso, usted ya debera haber entendido que existen ciertas normas a la hora de escribir el cdigo de un programa (como por ejemplo utilizar nombres apropiados de variables o tabular el cdigo) que tienen por objeto hacer que el cdigo del programa sea claro, legible y compresible. Estas normas de creacin de cdigo facilitarn enormemente el mantenimiento del programa, su entendimiento y disminuir el tiempo necesario para encontrar errores (punto este que le interesa enormemente). A continuacin resumimos algunas de estas normas que usted tiene la obligacin de seguir a la hora de desarrollar el cdigo en las prcticas de esta asignatura: a) Utilizar identificadores que sean los suficientemente representativos. A la hora de elegir el nombre de una variable, una constante o una funcin es importante que ste refleje el papel que cumple esa variable, constante o funcin dentro del programa. Por ejemplo nombres de variables como a, b o z son poco representativos. Recuerde que puede utilizar el signo de subrayado ( _ ) para crear nombres compuestos como: num_alumnos, altura_max, etc. No sea rcano a la hora de elegir el nombre de una variable, a veces merece la pena escribir dos o tres caracteres ms. Ejemplo: es mejor min que m, o alum en vez de al. b) Utilice las maysculas slo para los identificadores de las constantes, o para la primera letra del identificador de una funcin. c) Tabule cada bloque de cdigo. En C un bloque de cdigo se caracteriza por ir entre llaves ( {} ). Todo el cdigo que se encuentre entre esas llaves debera ir tabulado. Seguir esta norma resulta fundamental para poder leer el cdigo. Clarificaremos este hecho con un ejemplo: Mal uso de la tabulacin
#include <stdio.h> #include <stdlib.h> int main() { int num1,num2; system(cls); printf(Introduzca n1:); scanf(%i,&num1); printf(Introduzca n2:); scanf(%i,&num2); if (num1>num2){ printf(%d es el mayor,num1); printf(%d es el menor,num2);} else if (num1<num2){ printf(%d es el mayor,num2); printf(%d es el menor,num1);} else printf(Son iguales); system(pause); return 0; }
Fundamentos de Informtica Primero de Ingeniera Tcnica Industrial Mecnica, Qumica, Electricidad y Electrnica Departamento de Tecnologas de la Informacin
d) Utilice las llaves apropiadamente para separar cada bloque de cdigo. Procure que las llaves de finalizacin de bloque sirvan para ver de una forma ms clara dnde finaliza un bloque. Veamos algunas mejoras del ejemplo anterior:
#include <stdio.h> #include <stdlib.h> int main() { int num1, num2; system(cls); printf(Introduzca n1: ); scanf (%i, &num1); printf(Introduzca n2: ); scanf (%i, &num2); if (num1 > num2) { printf(%i es el mayor, printf(%i es el menor, } else if (num1 < num2) { printf(%i es el mayor, printf(%i es el menor, } else printf(Son iguales); system(pause); return 0; } } #include <stdio.h> #include <stdlib.h> void main() { int num1, num2; system(cls); printf(Introduzca n1: ); scanf (%i, &num1); printf(Introduzca n2: ); scanf (%i, &num2); if (num1 > num2) { printf(%i es el mayor, printf(%i es el menor, } else if (num1 < num2) { printf(%i es el mayor, printf(%i es el menor, } else printf(Son iguales); system(pause); return 0;
num1); num2);
num1); num2);
num2); num1);
num2); num1);
Como puede comprobar en ambos ejemplos, la aplicacin de esta regla junto con la anterior, nos permite ver rpidamente dnde comienza y termina un bloque. e) Utilice comentarios apropiadamente. Tan mal est un programa que no contiene ningn comentario como un programa con un nmero excesivo de ellos. Tenga en cuenta que los comentarios obvios son innecesarios. Debe usted suponer que la persona que lea el cdigo de su programa conoce el lenguaje de programacin en el que est escrito, por lo que no es necesario explicar para qu sirve cada instruccin. Los comentarios deben explicar los algoritmos complejos (qu hace un trozo de cdigo determinado o qu funcin tiene un bucle) cuando stos no sean obvios. Tambin debe comentar para que usa cada variable y cada funcin (volveremos al tema de comentar funciones cuando las veamos).
Fundamentos de Informtica Primero de Ingeniera Tcnica Industrial Mecnica, Qumica, Electricidad y Electrnica Departamento de Tecnologas de la Informacin
A continuacin mostramos dos claros ejemplos de dos cdigos, uno con los comentarios justos y otro con exceso de comentarios: Exceso de comentarios
//Programa que pide dos n por teclado //y nos dice cual es el mayor el menor //o si son iguales //Usamos el fichero de cabecera stdi.h //que nos permite usar las funciones //printf y scanf #include <stdio.h> #include <stdlib.h> //Definimos la funcin principal int main() { //Definimos num1 y num2 como enteras int num1, num2; //Primero borramos la pantalla system(cls); //As sacamos por pantalla la frase printf(Introduzca n1: ); //Leemos de teclado scanf (%i, &num1); //Pedimos el siguiente nmero printf(Introduzca n2: ); //Leemos de teclado scanf (%i, &num2); //Si num1>num2 entonces if (num1 > num2) { //Sacamos por pantalla printf(%i es el mayor, num1); printf(%i es el menor, num2); } //Sino se cumple la condicin vemos //si num1<num2 else if (num1 < num2) { //Sacamos por pantalla printf(%i es el mayor, num2); printf(%i es el menor, num1); } //Sino se cumple ninguna condicion //se hara esto else //Sacamos f) printf(Sonpor pantalla iguales); //Ahora hacemos una pausa system(pause); //Indicamos OK al SO return 0; }
Fundamentos de Informtica Primero de Ingeniera Tcnica Industrial Mecnica, Qumica, Electricidad y Electrnica Departamento de Tecnologas de la Informacin
f) Utilice una cabecera para cada programa. Acostmbrese a utilizar una cabecera informativa en los programas donde indique: funcin del programa, autor, fecha, errores conocidos. Este ltimo apartado es especialmente til cuando tenga que dejar de programar para dedicarse a otras cosas y su programa tenga fallos o est incompleto. As cuando retome el programa (seguramente varios das despus), con slo leer estas lneas sabr lo que estaba haciendo cuando lo dej la ltima vez.
//********************************************************************** //* Funcion: Programa que pide dos n por teclado y nos dice cual es el //* mayor el menor, o si son iguales //* Autor: DTI //* Fecha: 7-Marzo-08 //* Errores: Ninguno conocido. //********************************************************************* #include <stdio.h> #include <stdlib.h> void main() { int num1, num2; system(cls); //Pedimos los dos nmeros printf(Introduzca n1: ); scanf (%i, &num1); printf(Introduzca n2: ); scanf (%i, &num2); //Vemos cual es el mayor y el menor if (num1 > num2) { printf(%i es el mayor, num1); printf(%i es el menor, num2); } else if (num1 < num2) { printf(%i es el mayor, num2); printf(%i es el menor, num1); } else printf (Son iguales); system(pause); return 0; }
Recuerde que el mayor beneficiario de utilizar todas estas reglas es usted mismo. Escribir cdigo fcilmente legible es una de las piezas claves para evitar ciertos errores muy comunes (falta de llaves, etc.) y para encontrar los errores ms rpidamente y por tanto tardar menos tiempo en realizar los programas.
Fundamentos de Informtica Primero de Ingeniera Tcnica Industrial Mecnica, Qumica, Electricidad y Electrnica Departamento de Tecnologas de la Informacin
8. Ejercicios propuestos Con todo lo que ha visto en el Tema 5 de teora, usted ya puede comenzar a hacer programas en C. A continuacin le proponemos una serie de ejercicios: 1) Cul es la salida de los siguientes bucles?. Antes de responder piense primero sobre el papel la respuesta y despus comprubelo con el DevC++.
for (n=10; n>0; n=n-2) { printf (Hola); printf (%i \n, n); } for (n=0; n<=12; n++) { printf (Hola); printf (%i \n, n); }
for (n=1; n<=10; n++) { for (m=10; m>=1; m--) { printf (%i veces %i = %i \n, n, m, n*m); } }
2)
3)
Escriba un programa que lea un nmero entero por teclado y escriba la tabla de multiplicar de ese nmero Escriba un programa que muestre por pantalla la tabla de multiplicar de los 10 primeros nmeros (1,2,3....9,10.) Calcular la suma de las siguientes series: a)
4)
5)
1 1 1 1 + + + ..... 1 2 3 n
b)
1 2 3 4 n + 2 + 3 + 4 + ..... + n 2 2 2 2 2
donde n es un nmero entero introducido por teclado. 6) Realice un programa que lea nmeros enteros positivos hasta que se introduzca un 0. El programa deber mostrar por pantalla la cantidad de nmeros ledos, la media, as como el valor mximo introducido.
Fundamentos de Informtica Primero de Ingeniera Tcnica Industrial Mecnica, Qumica, Electricidad y Electrnica Departamento de Tecnologas de la Informacin
7)
Realice un programa que calcule y visualice el ms grade, el ms pequeo y la media de n nmeros (n>0). El valor de n se solicitar al principio del programa y los nmeros sern introducidos por el usuario.
8)
Realizar un programa que pida dos nmeros enteros por teclado y muestre por pantalla el siguiente men: MENU 1. Sumar 2. Restar 3. Multiplicar 4. Dividir 5. Salir Elija opcin: El usuario deber elegir una opcin y el programa deber mostrar el resultado por pantalla y despus volver al men. El programa deber ejecutarse hasta que se elija la opcin 5. Salir.
9)
Modificar el ejercicio anterior para que al elegir la opcin 5, en vez de salir del programa directamente, nos muestre el siguiente mensaje de confirmacin. MENU 1. Sumar 2. Restar 3. Multiplicar 4. Dividir 5. Salir Elija opcin: 5 Desea salir realmente (S/N)? De modo que si pulsamos el carcter s salgamos del programa, pero si pulsamos el carcter n, volvamos al men.
9. Ejercicios propuestos de un nivel de dificultad mayor Los ejercicios anteriores no presentaban una gran dificultad, por lo que su resolucin no debe haberle ocupado mucho tiempo. Los siguientes ejercicios tienen una complejidad mayor a los propuestos anteriormente. Si usted ha sido capaz de realizar los ejercicios anteriores, intente realizar los siguientes. As sabr si realmente domina el arte de la programacin de bucles:
10) Realice un programa que calcule el factorial de un nmero dado por teclado. Realice este ejercicio utilizando primero un bucle for y posteriormente repita el ejercicio utilizando un bucle while.
Fundamentos de Informtica Primero de Ingeniera Tcnica Industrial Mecnica, Qumica, Electricidad y Electrnica Departamento de Tecnologas de la Informacin
11) Realice un programa que determine si un nmero ledo del teclado es primo o no. 12) Un nmero perfecto es un entero positivo, que es igual a la suma de todos los enteros positivos (excluido l mismo) que son divisores del nmero. El primer nmero perfecto es 6, ya que los divisores de 6 son 1, 2, 3 y 1 + 2 + 3 = 6. Escriba un programa que lea un nmero entero positivo n y muestre por pantalla si ese nmero es o no perfecto. 13) Realice un programa que lea un nmero entero por teclado y devuelva por pantalla el nmero de dgitos que componen ese nmero. Por ejemplo, si introducimos el nmero 12334, el programa deber devolver 5. (Pista: utilice el operador %, averige para qu sirve y piense cmo utilizarlo). 14) Realice un programa que lea un nmero entero por teclado y devuelva por pantalla las que forman ese nmero. Por ejemplo, si se introduce el nmero 2345, el programa deber mostrar por pantalla 5 4 3 2. (Pista: utilice el ejercicio anterior como base para realizar este ejercicio).
10. Ejercicios que usan nmeros aleatorios para realizar juegos y simulaciones Una vez que domine el uso de las estructuras repetitivas usted ser capaz de realizar programas complejos. Quizs usted tenga en mente realizar algn pequeo juego o simulador, para lo cual debe conocer las funciones de librera del lenguaje C que permiten generar nmeros aleatorios.
Para generar un nmero entero aleatorio se debe utilizar la funcin rand( ). Si nos interesa que dicho nmero aleatorio est comprendido en un rango de valores determinado podemos usar el operador % para conseguir dicho propsito. As por ejemplo rand( ) % 100 genera un nmero aleatorio entre 0 y 99. Si no sabe por qu esto es as examine los siguientes casos, piense un poco y lo entender:
-
Al dividir 107 entre 100 el cociente es 1 y el resto es 7 Al dividir 399 entre 100 el cociente es 3 y el resto es 99 Al dividir 400 entre 100 el cociente es 4 y el resto es 0
Para que la secuencia de nmeros aleatorios sea distinta en cada ejecucin del programa, es necesario utilizar la funcin de biblioteca srand( ), que inicializa la semilla para la generacin de nmeros aleatorios en base a un valor dado como parmetro. De esta forma si utilizamos la expresin srand( time (0) ) fijaremos el valor de la semilla a la hora actual. La funcin time (0) devuelve la hora actual del sistema, con lo que en cada ejecucin del programa la semilla ser distinta al variar constantemente la hora del sistema. Las funciones rand( ) y srand( ) vienen definidas en el archivo de cabecera stdlib.h, mientras que la funcin time( ) viene definida en el archivo de cabecera time.h, por lo que es necesario aadir los siguientes ficheros cabecera a los programas que deseen hacer uso de estas funciones: #include <stdlib.h> #include <time.h>
Fundamentos de Informtica Primero de Ingeniera Tcnica Industrial Mecnica, Qumica, Electricidad y Electrnica Departamento de Tecnologas de la Informacin
Una vez explicado cmo generar nmeros aleatorios, intente implementar los siguientes juegos y simuladores: 15) Realizar un programa que simule un juego de adivinar un nmero. El programa pedir al usuario dos nmeros que representan el rango de valores entre los que se encuentra el nmero a adivinar, as como el nmero de intentos para adivinar el nmero. A continuacin el programa generar un nmero aleatorio entre esos dos nmeros y el usuario deber adivinarlo en el nmero mximo de intentos antes indicado. Cada vez que el jugador introduce un nmero el programa le dice si es mayor o menor y le indica cuantos intentos le quedan. (Pista: (x + rand( ) % y) genera un numero aleatorio en el rango [x , y1+x]). 16) Realice un programa que pregunte aleatoriamente la tabla de multiplicar. El programa debe indicar si la respuesta ha sido correcta o no (en caso que la respuesta sea incorrecta el programa debe indicar cual es la correcta). Una vez preguntado por una multiplicacin el programa debe preguntar si desea realizar otra. En caso afirmativo preguntar aleatoriamente otra multiplicacin. En caso negativo el programa finalizar. 17) Modificar el ejercicio anterior de modo que el programa pregunta aleatoriamente un total de n multiplicaciones siendo n un nmero dado por teclado. En cada multiplicacin el programa debe indicar si se ha acertado o no. Al final del programa, ste deber mostrar un resumen indicando el nmero de respuestas correctas y errneas, as como el porcentaje de aciertos y de fallos. 18) Realice un programa que genere aleatoriamente 7 operaciones aritmticas consecutivas a las que el usuario deber ir respondiendo correctamente para ir avanzando. Los nmeros (aleatorios) sobre los que se realizan las operaciones deben estar comprendidos entre 2 y 9 y las operaciones aritmticas (tambin aleatorias) permitidas sern la suma, resta, multiplicacin y divisin (en el caso de la divisin se realizar siempre una divisin entera). Ejemplo: 5 x 4 = 20 20 4 = 16 16 / 8 = 2 2 x 6 = 10 Incorrecto 2 x 6 = 12 12 7 = 2 Incorrecto 12 7 = 5 5 + 6 = 11 11 / 2 = 5
Fundamentos de Informtica Primero de Ingeniera Tcnica Industrial Mecnica, Qumica, Electricidad y Electrnica Departamento de Tecnologas de la Informacin
11. Conocimientos mnimos Despus de haber realizado esta prctica usted debera responder sin dilacin a las siguientes preguntas. Si no es as es que no ha aprendido lo suficiente, de modo que deber repasar algunos conceptos:
Qu Estructuras de Control Repetitivas ofrece el Lenguaje C y qu formato y diagrama de flujo tiene cada una de ellas. Cuntas veces se ejecuta como mnimo un bucle while? y un do-while? Qu tipo de bucle cree usted que es ms general?. Por qu? Cundo debe utilizar un bucle de tipo for? Cundo debe utilizar un bucle de tipo do-while? Cmo saber cundo utilizar un sentencia de control condicional o una sentencia de control repetitiva.
12. Errores comunes de programacin. A continuacin comentamos algunos errores tpicos que se suelen cometer al crear programas en C que utilizan bucles:
a) Usar comas (,) en vez de puntos y comas (;) en un encabezado de un bucle for.
Mal: for(n = 0, n < 10, n++) Bien: for(n = 0; n < 10; n++)
b) Colocar un punto y coma (;) inmediatamente a la derecha de un encabezado de un bucle for. Esto provoca que el cuerpo asociado al bucle sea un cuerpo vaco.
for(n = 1; n <= 5; n++); printf(%i , n); equivale a for( n = 1; n <= 5; n++) { ; } printf(%i , n);
c) Generar bucles infinitos. Para evitarlos: asegrese de que no exista un punto y coma despus del encabezado de una estructura while o for. Asegrese tambin, en aquellos bucles controlados por contadores o acumuladores: 1) primero que se inician a un valor correcto antes de comenzar el bucle, 2) y segundo que son incrementados o decrementados en cada iteracin.
n = 6; //ERROR tipo 1) while(n <= 5) { printf(%i , n); n++; } n = 1; while(n <= 5) { printf(%i , n); } //ERROR tipo 2)
d) Utilizar el operador de asignacin (=) como si fuera el operador de igualdad (= =). e) Usar un operador relacional incorrecto en las condiciones de los bucles.
13. La Frase....
El 20% del cdigo contiene el 80% de los errores. Encuntrelos y corrjalos!! Lowell Arthur.