Programación. Ejercicios Tema 5. Funciones

Documentos relacionados
Titulo: Suma de N primeros números

TEMA 5. CONTROL DE FLUJO DEL PROGRAMA. Sentencia Instrucción Expresión Operadores + Operandos Sintaxis: Sentencia ;

Programación. Ejercicios Tema 4 Estructuras de Control Repetitivas

Hoja de problemas Estructuras de Control

Para dudas, comentarios escribe a: C BASICO

Ejercicios Tema 3. Estructuras de Selección

Tema 4: Estructuras de Control Estructura y Contenidos

En cualquier caso, tampoco es demasiado importante el significado de la "B", si es que lo tiene, lo interesante realmente es el algoritmo.

Escuela Politécnica Superior de Ingeniería Departamento de Ingeniería Informática

Tema: Arreglos de Objetos en C++.

Tema 5 Sentencias de control de flujo. Fundamentos de Informática

Se guardan en archivos con extencion c y los cabezales con extension h

Un puntero no es más que una variable estática cuyo contenido es una dirección de memoria.

Curso 0 de Informática

Arreglos. // Incluir E/S y Librerías Standard #include <stdlib.h> #include <stdio.h>

LABORATORIO 1 OPERACIONES DE ENTRADA Y SALIDA

Ejercicio 1 (2 puntos. Tiempo: 25 minutos)

Estructuras de repetición

Centro de Capacitación en Informática

Objetivos de la práctica: - Practicar uso de ficheros: abrir, cerrar y tratamiento de información contenida en el fichero.

Informática I. While & do While

Paso de Borland Turbo C (bajo DOS) a Anjuta (Linux) 1.

Examen Junio- Grupo A Lunes 17 de Junio - Programación en C++ Pág. 1

PRÁCTICA N 2 SISTEMAS DE NUMERACIÓN

Introduccion al Lenguaje C. Omar Andrés Zapata Mesa Grupo de Fenomenología de Interacciones Fundamentales, (Gfif) Universidad de Antioquia

Índice ÍNDICE EJERCICIO 1: CÁLCULO FINANCIERO (5 PTOS.) EJERCICIO 2: AGENCIA DE COLOCACIONES (5 PTOS.)...4

EDWIN KÄMMERER ORCASITA INGENIERO ELECTRÓNICO

República Bolivariana de Venezuela Aldea Universitaria Liceo Fray Pedro de Agreda. Lenguaje C++ Contadores y Acumuladores

Prof. Dr. Paul Bustamante

INSTITUTO POLITECNICO NACIONAL. ESCUELA SUPEIRIOR DE INGENIERIA MECANICA Y ELECTRICA. UNIDAD CULHUACAN. INTEGRANTES: FLORES ACOLTZI ONESIMO

ETS Caminos Santander. Curso Ejercicios de introducción a la programación.

Llamamos potencia a todo producto de factores iguales. Por ejemplo: 3 4 =

Práctica 2: Simón dice

Funciones en Lenguaje C.

Informática FACULTAD DE FÍSICAS

Capítulo 4 Procesos con estructuras de repetición

INTRODUCCIÓN AL TIPO COMPUESTO CADENA CONTENIDOS

Tema: Sobrecarga de Operadores.

MATERIAL 2 EXCEL 2007

OPERADORES LÓGICOS Y DE COMPARACIÓN EN PHP. PRIORIDADES. EJEMPLOS. EJERCICIOS RESUELTOS. (CU00818B)

EJERCICIOS DE PROGRAMACIÓN RELACIÓN VII (EJERCICIOS DE REPASO)

LENGUAJE. Tema 1 - Introducción

Introducción al tipo de dato ARRAY

Prof. Dr. Paul Bustamante

LÍMITES Y CONTINUIDAD

Sistema de Gestión Académica TESEO. Revisión 1.0. Servicio de Informática Área de Gestión (GESTIÓN DE RESÚMENES DE TESIS DOCTORALES)

Estructuras de Control en C

LINUX - Los archivos de órdenes I

Proyectos de Innovación Docente

Tema 6. Reutilización de código. Programación Programación - Tema 6: Reutilización de código

Índice Introducción Números Polinomios Funciones y su Representación. Curso 0: Matemáticas y sus Aplicaciones Tema 1. Números, Polinomios y Funciones

Clases y Objetos. Informática II Ingeniería Electrónica

PRÁCTICA 1: INTRODUCCIÓN A LA ALGORÍTMICA BOLETIN DE PROBLEMAS RESUELTOS. (Curso 03-04)

Divisibilidad y números primos

8.1 Un primer bucle FOR Varias formas de utilizar el bucle FOR Calcular el factorial de un número mediante un bucle FOR...

Instructivo de Microsoft Excel 2003

Ejemplos de conversión de reales a enteros

FUNDAMENTOS DE INFORMÁTICA 1º Ingeniería Industrial

Lenguaje C Bucles, Condicionales, operadores y Algoritmos.

Tema 2. Memoria Dinámica. 2.1 Datos estáticos y dinámicos

INTELIGENCIA ARTIFICIAL 2015 TALLER RÁPIDO DE PROGRAMACIÓN EN JAVA

Los polinomios. Un polinomio es una expresión algebraica con una única letra, llamada variable. Ejemplo: 9x 6 3x 4 + x 6 polinomio de variable x

A25. Informática aplicada a la gestión Curso 2005/2006 Excel Tema 7. Funciones avanzadas de Excel II

TEMA 3: EL LENGUAJE C: PRESENTACIÓN

Examen Principios de Programación Febrero 2012

Base de datos en Access

Polinomios: Definición: Se llama polinomio en "x" de grado "n" a una expresión del tipo

Problemas + PÁGINA 37

VARIABLES, CONSTANTES Y EXPRESIONES ASIGNACIÓN. TIPOS ELEMENTALES. PRECEDENCIA DE LOS ESTRUCTURAS DE CONTROL. CONDICIONAL E

LECCIÓN 4ª Operaciones Numéricas

CONSEJOS PARA MAQUETAR LA TESIS DOCTORAL

AUTOR CARLOS EDUARDO BUENO VERGARA JORGE ARMANDO BUENO VERGARA USO DE LOS OBJETOS DEL PROGRAMA. Dfd INFORMÁTICA II PROFESOR. JOSÉ FRANCISCO AMADOR

INVENTARIO INTRODUCCIÓN RESUMEN DE PASOS

LÍMITES DE FUNCIONES. CONTINUIDAD

CAPÍTULO 4. FÓRMULAS Y FUNCIONES

Preliminares. Tipos de variables y Expresiones

Vectores. 27/05/05 Programación Digital I 1

Centro de Capacitación en Informática

Manual de usuario. Tramitación de inspecciones periódicas de ascensores: La visión de las empresas conservadoras

ESTRUCTURAS CONDICIONALES EN PHP: SWITCH, CASE, BREAK. EJEMPLOS DE USO Y EJERCICIOS RESUELTOS. (CU00820B)

Ecuaciones de primer grado con dos incógnitas

De dos incógnitas. Por ejemplo, x + y 3 = 4. De tres incógnitas. Por ejemplo, x + y + 2z = 4. Y así sucesivamente.

Programación: QBASIC

Dra. Carmen Ivelisse Santiago Rivera 1 MÓDULO DE LOS ENTEROS. Por profesoras: Iris Mercado y Carmen Ivelisse Santiago GUÍA DE AUTO-AYUDA

PRÁCTICA 5. SENTENCIAS DE CONTROL REPETITIVAS.

FOCO GESTIÓN DE GRUPOS

CASO PRÁCTICO DISTRIBUCIÓN DE COSTES

LEER Y ESCRIBIR ARCHIVOS O FICHEROS EN C. FOPEN, FCLOSE, MODOS DE ACCESO READ, WRITE Y APPEND (CU00536F)

Tema 7: Programación con Matlab

Adivinanza o logaritmos?

Polinomios y Ecuaciones

Memoria compartida y semáforos r/w. La página del manual que podría servir para describir estas funciones es la siguiente:

1. Introducción. 1.1 Ejercicio 1: Estación Meteorológica (4.0 pts.) Ejercicio 2: Gestión Académica: Alumnos (5.0 pts.)...

Examen escrito de Programación 1

7. Manejo de Archivos en C.

RECUPERAR DATOS DE UN FORMULARIO HTML USANDO PHP. USO DE $_GET. EJEMPLOS Y EJERCICIOS RESUELTOS. (CU00833B)

PRACTICA 6. VECTORES Y MATRICES.

Prof. Dr. Paul Bustamante

CASO PRAÁ CTICO PREÁ STAMOS. CAÁLCULO DE PERIODOS Y VA

Transcripción:

Programación Ejercicios Tema 5 Autores: M. Paz Sesmero Lorente Paula de Toledo Heras Fco. Javier Ordoñez Morales Juan Gómez Romero Jose A. Iglesias Martínez Jose Luis Mira 1

SOLUCIONES 1. Escriba una función que devuelva el resultado de elevar un número (declarado como entero) a cualquier potencia (valor entero). El resultado de este cálculo debe ser de tipo long. long potencia(int x, int n); int main(void) int b; int e; /* Elevar a cualquier potencia */ printf("introduce base: "); scanf("%ld", &b); printf("introduce exponente: "); scanf("%i", &e); printf("%d elevado a %i es %ld \n", b, e, potencia(b, e)); system("pause"); return 0; long potencia(int x, int n) /* Funcion potencia: * Eleva el valor x al exponente n * Argumentos: x Base (int) n Exponente (int) Valor de retorno: x^n (long) */ long ret = x; int i; for(i=1; i<n; i++) ret = ret * x; return ret; 2. Escriba una función que reciba dos números reales positivos como parámetros y devuelva el máximo de los dos valores. float max(float x, float y); int main(void) float a, b; printf("introduzca a: "); scanf("%f", &a); 2

printf("introduzca b: "); scanf("%f", &b); printf("mayor: %f\n", max(a, b)); system ("PAUSE"); return 0; float max(float x, float y) /* Función max: Devuelve el mayor de los valores x, y pasados como parámetro */ float max; if(x >= y) max = x; max = y; return max; 3. Escriba un programa en C que muestre el siguiente menú: CALCULO DE AREAS =========================== 1 - Calcular el área de un triángulo 2 - Calcular el área de un trapecio 3 - Calcular el área de un rectángulo Y lea la opción introducida por el usuario. En función de la opción el programa deberá pedir los datos necesarios para calcular el área, realizar el cálculo y mostrar el resultado por pantalla. Utilice una función para mostrar el menú, y otras tres para calcular el área de los distintos polígonos (triángulo, trapecio rectángulo). El valor de retorno de cada una de estas tres últimas funciones debe ser el área calculada. int mostrarmenu(void); float CalcularAreaTriangulo(void); float CalcularAreaTrapecio(void); float CalcularAreaRectangulo(void); int main(void) int opcion; //Para almacenar la opción elegida float area; //Almacena el área calculadoa opcion=mostrarmenu(); switch(opcion) case 1: area=calcularareatriangulo(); printf("el area del triangulo es %4.2f\n",area); break; case 2: area=calcularareatrapecio(); printf("el area del trapecioes %4.2f\n",area); 3

break; case 3: area=calculararearectangulo(); printf("el area del cuadrado es %4.0f\n",area); break; default: printf("fin del programa."); system ("PAUSE"); return 0; int mostrarmenu(void) /* Función que muestra por pantalla un menú y devuelve la opción seleccionada*/ int opcion; printf("calculo DE AREAS \n"); printf("============================ \n\n\n"); printf("1 - Calcular el área de un triangulo \n"); printf("2 - Calcular el área de un trapecio \n"); printf("3 - Calcular el área de un rectangulo \n\n\n"); printf("opcion: "); scanf("%d",&opcion); return (opcion); float CalcularAreaTriangulo(void) /* Función que calcula y devuelve el área de un triángulo.*/ /* base y altura deben ser valores enteros */ float area; int base, altura; printf("area DEL TRIÁNGULO \n"); printf("base: "); scanf("%d",&base); printf("altura: "); scanf("%d",&altura); //Para conseguir un valor real se hace una conversión explícita area=(float)base*altura/2; return (area); float CalcularAreaTrapecio(void) /* Función que calcula y devuelve el área de un trapecio */ /* base_mayor, base_menor y altura deben ser valores enteros */ float area; int base_mayor, base_menor, altura; printf("area DEL TRAPECIO \n"); printf("base mayor: "); scanf("%d",&base_mayor); printf("base menor: "); scanf("%d",&base_menor); 4

printf("altura del trapecio: "); scanf("%d",&altura); //Para conseguir un valor real se utiliza 2.0 area=((base_mayor+base_menor)/2.0)*altura; return (area); float CalcularAreaRectangulo(void) /* Función que calcula y devuelve el área de un trapecio */ /* base y altura deben ser valores enteros */ float area; int base, altura; printf("area DE UN RECTANGULO \n"); printf("base: "); scanf("%d",&base); printf("altura: "); scanf("%d",&altura); //En ese caso y dado que base y altura son reales el resultado //siempre será real area=(float)base*altura; return (area); 4. Escriba una función que intercambie los valores de dos variables de tipo entero. void swap(int *x, int *y); int main(void) int a, b; printf("introduzca a: "); scanf("%i", &a); printf("introduzca b: "); scanf("%i", &b); printf("\nantes de intercambio\n"); printf("a: %i\n", a); printf("b: %i", b); swap(&a, &b); printf("\ndespues de intercambio\n"); printf("a: %i\n", a); printf("b: %i\n", b); return 0; void swap(int *x, int *y) /* Función que intercambia el valor de dos variables. Para conseguir que los cambios sean visibles en el programa principal los parámetros se deben pasar por referencia*/ int temp; temp = *x; *x = *y; *y = temp; 5

5. La nota del examen de una asignatura corresponde en un 20% al primer parcial, un 20% al segundo parcial y un 60% el examen final. La nota final es la mejor entre la nota del examen y la nota obtenida con la evaluación continua (teniendo en cuenta los dos parciales). Escriba un programa que pida estas tres notas y calcule la nota final de un alumno. A continuación, el programa debe preguntar al usuario si quiere calcular una nueva nota o finalizar (pulsando la tecla s ). Utilice una función para calcular la nota y otra para obtener el máximo (que puede ser la desarrollada en el ejercicio 2). float calcularmax(float x, float y); float calcularnota(float p1, float p2, float e); int main(void) char c; do float parcial1, parcial2, examen, final; /* Leer valores */ printf("introduzca nota parcial 1 [0, 10]: "); scanf("%f", &parcial1); printf("introduzca nota parcial 2 [0, 10]: "); scanf("%f", &parcial2); printf("introduzca nota examen final [0, 10]: "); scanf("%f", &examen); /* Calcular nota final*/ final = calcularnota (parcial1, parcial2, examen); /* Imprimir resultados */ printf("nota final: %f", final); /* Continuar? */ printf("\n\nsalir? (s/n): "); /* Para evitar conflictos con el salto de linea (\n) y evitar un bucle infinito se recurre al siguiente "truco" */ do scanf("%c", &c); while (c=='\n'); printf("\n"); while(c!= 's'); return 0; float calcularnota (float p1, float p2, float notaexamen) /* Función calcularnota: Calcula la nota final a partir de: - primer parcial 20% (p1) - segundo parcial 20% (p2) - examen final 60% (notaexamen) Si la nota final con la evaluación continua es menor a la del examen, la nota final es la del examen */ 6

float notaec, final; notaec = p1*0.2+p2*0.2+notaexamen*0.6; final = calcularmax(notaec, notaexamen); return final; float calcularmax(float x, float y) /* Funcion calcularmax: Devuelve el mayor de los valores x, y pasados como parámetro */ float max; if(x >= y) max = x; max = y; return max; 6. Realizar un programa en C que verifique si existe o no concordancia entre los datos de un NIF (DNI y letra) introducido por teclado. Para ello: a. Tras solicitar el DNI se debe comprobar que el valor introducido es positivo y tiene a lo sumo 8 dígitos. En caso de no cumplir estas condiciones se ha de indicar que el DNI introducido es incorrecto y se pedirá un nuevo valor. En la fase de verificación se debe utilizar una función que reciba como parámetro el número del DNI y, tras hacer las comprobaciones pertinentes, devuelva el valor VERDADERO (1) o el valor FALSO (0). b. Una vez introducido un DNI correcto, se solicitará una letra y el programa debe determinar si DNI y letra son concordantes. Para ello el alumno debe: b.1. Implementar una función que dado el número del DNI, devuelva la letra que le corresponde. Para calcular dicha letra hay que tener en cuenta que la misma es función del resto obtenido al dividir el número del DNI entre 23. La relación entre ambos parámetros es: Resto Letra Resto Letra Resto Letra 0 T 8 P 16 Q 1 R 9 D 17 V 2 W 10 X 18 H 3 A 11 B 19 L 4 G 12 N 20 C 5 M 13 J 21 K 6 Y 14 Z 22 E 7 F 15 S b.2 Implementar una función que reciba, entre otros parámetros, la letra del DNI introducida por el usuario y devuelva si dicha letra corresponde o no al DNI introducido. 7

c. Al final, el programa debe indicar al usuario si el NIF introducido es o no correcto. Nota: En la resolución de este problema se sugiere hacer uso de las siguientes funciones contenidas en la biblioteca estándar ctype.h. int isalpha(int c); Devuelve verdadero si c es una letra int toupper (int c); Devuelve el carácter en mayúscula correspondiente al carácter pasado por parámetro. #include <ctype.h> int validardni(int n); int verificarletranif(int dni, char letra); char calcularletranif(int n); int main(void) int dni; int ok; char letra; do printf ("Introduzca su DNI: "); scanf("%d", &dni); ok=validardni(dni); if (ok==0) printf("el numero de DNI introducido no es correcto\n"); while (ok==0); do printf("introduzca la letra del NIF: "); do scanf("%c", &letra); while (letra=='\n'); ok=isalpha(letra); if (ok==0) printf("el caracter introducido no es letra. Por favor, introduzca una letra\n"); letra=toupper(letra); while (ok==0); ok=verificarletranif(dni, letra); if (ok==1) printf("su NIF es %d%c y lo ha introducido correctamente\n", dni, letra); printf("la letra del NIF es incorrecta\n"); system ("PAUSE"); return (0); int validardni(int n) int valido=1; if ((n<0) (n>99999999)) valido=0; return (valido); 8

char calcularletranif(int n) int resto; char letra; resto=n%23; switch (resto) case 0: letra='t'; break; case 1: letra='r'; break; case 2: letra='w'; break; case 3: letra='a'; break; case 4: letra='g'; break; case 5: letra='m'; break; case 6: letra='y'; break; case 7: letra='f'; break; case 8: letra='p'; break; case 9: letra='d'; break; case 10: letra='x'; break; case 11: letra='b'; break; case 12: letra='n'; break; case 13: letra='j'; break; case 14: letra='z'; break; case 15: letra='s'; break; case 16: letra='q'; break; case 17: letra='v'; break; case 18: letra='h'; break; case 19: letra='l'; break; case 20: letra='c'; break; case 21: letra='k'; break; case 22: letra='e'; break; return (letra); int verificarletranif(int dni, char letra) char letracorrecta; int ok; letracorrecta=calcularletranif(dni); if (letra==letracorrecta) ok=1; ok=0; return (ok); 7. Realizar un programa que pida al usuario información de un día/mes/año posterior al 1978 y a continuación le muestre al usuario el día de la semana con que se corresponde esa fecha. Para realizar este cálculo la única información disponible es que el 1 de Enero de 1978 fue domingo. Para realizar el ejercicio conviene tener en cuenta que el día de la semana se puede obtener a partir del número de días transcurridos entre la fecha introducida por el usuario y la fecha de referencia (1 de enero de 1978). Una vez conocido este valor, el día de la semana vendrá dado por: dia_semana=n_dias_transcurridos % 7 En la resolución de este ejercicio se deben usar las siguientes funciones: 9

a) void leerfecha(int *dia, int *mes, int *year); Objetivo: Solicita los datos relatives a una fecha hasta que éstos se correspondan con una fecha válida. b) int validarfecha (int dia, int mes, int year); Valor de retorno: 1 si la fecha introducida es válida (posterior al 01/01/1978; 0<mes<13; 0<d<=días_mes) y 0 en caso contrario. c) int calculardias(int dia, int mes, int year); Valor de retorno: Número de días que hay entre una determinada fecha y el 1 de Enero de 1978. Para realizar correctamente este cálculo se requiere identificar los años bisiestos d) int aniobisiesto(int year); Valor de retorno: 1 si el año es bisiesto y 0 en caso contrario. Nota: Un año es bisiesto si es múltiplo de 4 excepto aquellos divisibles por 100 a no ser que lo sean por 400. Así, por ejemplo, los años 1500, 1700, 1800, 1900 y 2100 son años no bisiestos mientras que los años 1600, 1200 ó 2400 sí son años bisiestos. int aniobisiesto(int year); int validarfecha (int d, int m, int a); int calculardias(int d, int m, int a); void leerfecha(int *d, int *m, int *a); int main(void) int dia, mes, anio; int totaldias; int resto; printf("por favor, introduzca una fecha posterior al 1 de Enero de 1978\n"); leerfecha(&dia, &mes, &anio); totaldias=calculardias(dia, mes, anio); resto=totaldias%7; printf("el dia %d/%d/%d será ", dia, mes, anio); switch (resto) case 0: printf("domingo\n");break; case 1: printf("lunes\n");break; case 2: printf("martes\n");break; case 3: printf("miercoles\n");break; case 4: printf("jueves\n");break; case 5: printf("viernes\n");break; case 6: printf("sabado\n"); system ("PAUSE"); return (0); int aniobisiesto(int year) /* Dado un año determina si éste es bisiesto o no Para ello hay que saber que los años bisiestos son aquellos que son divisibles por 4 pero no por 100 o divisibles por 4 y por 400 */ int bisiesto=0; 10

if ( ((year%4) == 0) && (((year%100)!=0) ((year%400)==0)) ) bisiesto=1; //Si el año no es divisible por 4 no es bisiesto return bisiesto; int validarfecha (int d, int m, int a) /* Comprueba que los datos introducidos corresponden a una fecha válida: año > 1978 1>=mes<=12 1>=dia<=dias mes Para el último cálculo es necesario conocer los días que tiene el mes introducido (31, 30, 29 ó 28)*/ int diasmes; int bisiesto; int correcta; correcta=1; /*Se comprueba la validez del año*/ if (a<1978) printf("la fecha introducida debe ser posterior al 1 de Enero de 1978\n"); correcta=0; /*Si el año es válido se comprueba la validez del mes*/ if ((m<1) (m>12)) printf("el mes introducido no es válido\n"); correcta=0; /*Si el mes es válido se determina el núm. de días del mes*/ switch (m) case 1: case 3: case 5: case 7: case 8: case 10: case 12: diasmes=31; break; case 4: case 6: case 9: case 11: diasmes=30; break; case 2: /*Para determinar si febrero tiene 28 o 29 días se analiza si el año es bisiesto*/ bisiesto=aniobisiesto(a); if (bisiesto==1) diasmes=29; diasmes=28; //switch if ((d<0) (d>diasmes)) correcta=0; printf("el día introducido no es valido\n"); //if ((d<0) (d>diasmes) // return (correcta); void leerfecha(int *d, int *m, int *a) 11

/*Lee una fecha y devuelve los valores leidos *d: dia *m: mes *a: año al programa principal Para conseguir este objetivo los parámetros se pasan por referencia*/ int valida; do printf ("Dia: "); scanf("%d", d); /*Puesto que en este caso d, m y a son punteros se omite El operador dirección (&) en la llamada a scanf*/ printf ("Mes: "); scanf("%d", m); printf ("Year: "); scanf("%d", a); valida=validarfecha(*d, *m, *a); while (valida==0); int calculardias(int d, int m, int a) /*Determina el número de dias transcurridos entre la fecha introduciday el 1 de enero de 1978*/ int i; int bisiesto; int dias=0; /*Por cada año transcurrido hasta llegar al de la fecha introducida se suman 365 ó 366 días según corresponda*/ for (i=1978; i<a; i++) bisiesto=aniobisiesto(i); if (bisiesto==1) dias=dias+366; dias=dias+365; /*Por cada mes transcurrido hasta llegar al de la fecha introducido se suman 31, 30, 29 ó 28 días según corresponda*/ for (i=1; i<m; i++) switch (i) case 1: case 3: case 5: case 7: case 8: case 10: case 12: dias=dias+31; break; case 4: case 6: case 9: case 11: dias=dias+30; break; case 2: bisiesto=aniobisiesto(a); if (bisiesto==1) dias=dias+29; dias=dias+28; //switch;*/ ;//for /*Se añaden los días no contabilizados*/ dias=dias+d-1; //El día en curso no se contabiliza return (dias); 12

8. Escribir un programa que solicite al usuario un número natural y el número de decimales que se quiere contemplar al calcular su raíz. Una vez introducidos estos datos, se debe mostrar por pantalla el resultado de: a) Realizar la raíz cuadrada usando el método de las aproximaciones sucesivas. b) Calcular el factorial de ese número. c) Indicar si el número introducido es primo o no. Un número primo es aquel que sólo es divisible por sí mismo y por el número 1. Por convenio, el número 1 no se considera primo double calcularraiz(int n, int decimales); long calcularfactorial(int n); int comprobarprimo(int n); int main(void) int n; int decimales; double raiz; long factorial; int primo; //Solicitamos un número hasta que éste sea positivo do printf("introduzca el número del que quiere calcular la raiz\n"); scanf ("%d", &n); if (n<0) printf("error: No se puede calcular la raiz de un número negativo\n"); while (n<0); //Solicitamos el número de decimales que tendrá la aproximación. Este número debe ser positivo: do printf ("Introduza el número de decimales que tendrá la aproximación\n"); scanf ("%d", &decimales); while (decimales<0); raiz=calcularraiz(n, decimales); factorial=calcularfactorial(n); primo=comprobarprimo(n); //Mostramos resultados printf ("La raiz cuadrada de %d es %lf\n", n, raiz); printf ("Su Factorial es %ld\n", factorial); if (primo==1) printf ("Ademas, el numero es primo\n"); printf ("Ademas, el numero NO es primo\n"); return (0); 13

double calcularraiz(int n, int decimales) /*PARAMETROS int n; //Numero del que queremos calcular la raíz int decimales; //Numero de decimales a los que vamos a aproximar*/ //Variables locales double raiz; /*Numero con el que probaremos si es la raiz. Valor de Retorno*/ float incremento; int dec; //Numero de decimales a los que vamos a aproximar //y número de decimales con los que estamos //realizando el cálculo //Inicializamos raiz al menor entero posible, es decir, a 0: raiz=0; incremento=1.0; /*Inicialmente buscamos el entero más próximo a la raiz; Es decir, probaremos con números que difieren entre sí en 1 unidad. Por tanto, el número de decimales para la Primera aproximación es 0 */ dec=0; while ((n>(raiz*raiz) )&&(decimales>=dec)) while(raiz*raiz<n) raiz=raiz+incremento; //Al salir del bucle, el valor almacenado en raiz será mayor // o igual que el número buscado. //Si es mayor (nos hemos pasado), actualizamos el valor de //raiz if (raiz*raiz!=n) raiz=raiz-incremento; //Ajustamos a un nuevo decimal incremento=incremento/10.0; dec++; //while return (raiz); long calcularfactorial(int n) long factorial; factorial=1; int i; //Dado que el factorial tanto de 0 como de 1 es 1, el caso //genérico se da para n>=2. En este caso: //n!=1*2*3*...*n for (i=2; i<=n; i++) factorial=factorial*i; return (factorial); comprobarprimo(int n) int primo; int i; 14

int divisor; if (n==1) primo=0; primo=1; //Se admite que el número es primo divisor=2; //Se intenta localizar algún divisor del número dado while ((primo==1)&&(divisor<n)) if (n%divisor==0) primo=0; divisor=divisor+1; //Si el número sigue siendo //primo probamos con //otro divisor return (primo); 15