Fflush
Fflush
Fflush
#include <stdio.h>
int main()
{
char a, b, c;
return 0;
}
La primera vez que se ejecuta scanf, el buffer del teclado está vacío, por tanto, no es
preciso utilizar fflush, pero sí, en los dos casos posteriores. Obsérvese que, a fflush hay
que indicarle el buffer a limpiar, Standar Input (stdin) en este caso.
Switch
Anidar ciclos
do
{
} while ( <expresión_lógica> );
Ejemplo: Se quiere escribir un programa que muestre por pantalla la tabla de multiplicar
de un número entero introducido por el usuario. El proceso debe repetirse mientras que el
usuario lo desee:
7*1=7
7 * 2 = 14
7 * 3 = 21
7 * 4 = 28
7 * 5 = 35
7 * 6 = 42
7 * 7 = 49
7 * 8 = 56
7 * 9 = 63
7 * 10 = 70
-12 * 1 = -12
-12 * 2 = -24
-12 * 3 = -36
-12 * 4 = -48
-12 * 5 = -60
-12 * 6 = -72
-12 * 7 = -84
-12 * 8 = -96
-12 * 9 = -108
-12 * 10 = -120
#include <stdio.h>
int main()
{
char seguir;
int i, numero;
do
{
printf( "\n Introduzca un numero entero: " );
scanf( "%d", &numero );
return 0;
}
Pow
En lenguaje C, para realizar operaciones con potencias se utiliza una función de su
biblioteca estándar, en concreto la función pow, a la que hay que "darle" (pasarle) dos
operandos entre paréntesis. La sintaxis de su llamada es:
En lenguaje C:
int numero = 9;
De la expresión:
En pseudocódigo:
1 + numero ** 2
En lenguaje C:
1 + pow( numero, 2 )
#include <math.h>
++ --
En lenguaje C, tanto el operador incremento (++) como el operador decremento (--) actúan siempre
sobre un solo operando, normalmente una variable. Por tanto, son operadores monarios, y sirven
para incrementar o decrementar en una unidad el valor de dicho operando.
int r = 8, s = 3;
r++;
s--;
r = r + 1;
s = s - 1;
++r;
--s;
int i = 5, j, k = 5, m;
j = i++;
m = ++k;
Obsérvese que, los valores de j y m son diferentes. Esto es debido a que, cuando se evalúa la
expresión j = i++, en primer lugar, se le asigna a j el valor de i (es decir, un 5) y, a continuación, se
incrementa el valor de la variable i. Por el contrario, cuando se evalúa la expresión m = ++k,
primero, se incrementa el valor de k (de 5 pasa a ser 6) y, después, este nuevo valor de k se le
asigna a m.
En resumen, cuando en una expresión el operador incremento (++) o decremento (--) precede al
operando sobre el que actúa (por ejemplo ++k), antes de utilizar el valor de dicho operando para
otro propósito, este se incrementa. De ser al revés, es decir, si es el operando quien precede al
operador (por ejemplo i++), el valor de dicho operando se incrementa después de ser utilizado para
otro fin.
Números primos
#include <stdio.h>
#include <stdlib.h>
int main(int argc, char *argv[]) {
int num1,i,a;
char resp;
do{
a=0; /*Esta variable la vamos a usar para contar los divisores del número introducido, la
inicializamos a 0*/
fflush( stdin );
printf("Introduce un numero: ");
scanf("%d",&num1);
for(i=1;i<=num1;i++)
{
if(num1%i==0) // si num1 módulo de i es 0, incrementamos a en 1.
a++;
}
if (a==2) { //si al final a vale 2 es primo porque tiene 2 divisores
printf("\nEs primo");
} else {
printf("\nNo es primo");
}
fflush( stdin );
printf("\n\nDesea introducir otro número S/N: ");
scanf ("%c",&resp);
printf("\n\n");
}while (resp=='s' || resp=='S');
return(0);
}
Números felices
#include <stdio.h>
#include <math.h>
if (Numero < 0)
{
printf("Introduce un numero valido.\n");
}else{
int i = 0;
int suma = 0;
int z = 0;
suma = 0;
for (i = 0; i < 10; i++)
{
suma = suma + Numeros[i];
}
if (suma == 1)
{
printf("Numero Feliz :)\n");
return 0;
}
suma = 0;
for (i = 0; i < 10; i++)
{
suma = suma + pow(Numeros[i], 2);
}
Numero = suma;
memset(Numeros,0,40);
z++;
}
printf("El numero NO es feliz :(\n");
}
return 0;
}
Secuencia de Fibonacci
#include <stdio.h>
#include <stdlib.h>
int main(int argc, char *argv[])
{
int n=0, o, serie, m, k, b,q,w,e,r,t,y,u;
printf("Elija la opcion deseada\n");
printf("\n1.- Generar serie de 5 numeros \t");
printf("\n2.- Generar serie de 12 numeros\t");
printf("\n3.- Salir\t");
scanf("%d", &o);
if (o==1)
{
for (n=0; n<2; ++n)
{
serie=n;
n=serie+1;
m=n+serie;
b=m+n;
k=b+n;
printf("\n\n\n");
printf("%d", serie);
printf("%d", n);
printf("%d", m);
printf("%d", b);
printf("%d", k);
}
}
if (o==2)
{
for (n=0; n<2; ++n)
{
serie=n;
n=serie+1;
m=n+serie;
b=m+n;
k=b+n;
q=k+b;
w=q+k;
e=w+q;
r=e+w;
t=r+e;
y=t+r;
u=y+t;
printf("\n\n\n");
printf("%d-", serie);
printf("%d-", n);
printf("%d-", m);
printf("%d-", b);
printf("%d-", k);
printf("%d-", q);
printf("%d-", w);
printf("%d-", e);
printf("%d-", r);
printf("%d-", t);
printf("%d-", y);
printf("%d", u);
}
}
if (o==3)
printf("\n\nHasta pronto");
getchar();
getchar();
return 0;
}
#include <conio.h>
#include <stdio.h>
void main()
{
int edad;
char nombre[20], sexo;
printf("Nombre :");
scanf("%s",&nombre);
printf("Edad :");
fflush(stdin); //limpiar el buffer del teclado
scanf("%d",&edad);
printf("Sexo :");
fflush(stdin); //limpiar el buffer del teclado
scanf("%c",&sexo);
printf("\n***datos***");
printf("\nNombre: %s", nombre);
printf("\nEdad: %d", edad);
printf("\nSexo: %c", sexo);
getch(); //pausa
}
1. #include <stdio.h>
2. #include <stdlib.h>
3.
4. int main()
5. {
6. char Nombre[3][50];
7. int Edad[3];
8. int Contador=0;
9.
10.
11. // Solicitar las tres edades y nombres
12. for( Contador=0;Contador<3;Contador++ ) {
13. printf("Nombre ...: ");
14. scanf(" %[^\n]",Nombre[Contador]);
15. printf("Edad .....: ");
16. scanf(" %d",&Edad[Contador]);
17. }
18.
19. // Diferenciar al mayor
20. if(Edad[0]>Edad[1]) {
21. if(Edad[0]>Edad[2]) {
22. printf("\nEl mayor es %s con una edad de %d",Nombre[0],Edad[0]);
23. printf("\nEl mediano es %s con una edad de %d",Nombre[2],Edad[2]);
24. printf("\nEl menor es %s con una edad de %d",Nombre[1],Edad[1]);
25. } else {
26. printf("\nEl mayor es %s con una edad de %d",Nombre[2],Edad[2]);
27. printf("\nEl mediano es %s con una edad de %d",Nombre[0],Edad[0]);
28. printf("\nEl menor es %s con una edad de %d",Nombre[1],Edad[1]);
29. }
30. } else {
31. if(Edad[1]>Edad[2]) {
32. printf("\nEl mayor es %s con una edad de %d",Nombre[1],Edad[1]);
33. printf("\nEl mediano es %s con una edad de %d",Nombre[2],Edad[2]);
34.
35. return 0;
36. } printf("\nEl menor es %s con una edad de %d",Nombre[0],Edad[0]);
37. } else {
38. printf("\nEl mayor es %s con una edad de %d",Nombre[2],Edad[2]);
39. printf("\nEl mediano es %s con una edad de %d",Nombre[1],Edad[1]);
40. printf("\nEl menor es %s con una edad de %d",Nombre[0],Edad[0]);
41. }
Cadenas
Vamos ahora a ver cómo manejar texto con C. Para empezar, es preciso decir que existe
un tipo string como en otros lenguajes, pero no existe un tipo de datos específico para
almacenar texto, sino que se utilizan arrays de char. Funcionan igual que los
demás arrays con la diferencia de que ahora se manejan letras en vez de números. Se les
llama cadenas, strings o tiras de caracteres y a partir de ahora les llamaremos cadenas.
Para declarar una cadena se hace como en el caso de un array. Por ejemplo, si queremos
declarar una cadena de longitud 20 caracteres se haría:
char texto[20];
#include <stdio.h>
main()
{
char nombre[20];
Obsérvese que en la sentencia scanf no se usa el símbolo & delante de nombre. No hace
falta porque se trata de un array, de modo que escribir el nombre del array es equivalente
a poner &nombre[0].
También puede llamar la atención sobre la forma de imprimir el array. Con sólo
usar %s ya se imprime su totalidad. Ya veremos esto más adelante.
Por si alguien está acostumbrado a programar en otro lenguaje es preciso hacer notar que
en C no se puede hacer esto:
#include <stdio.h>
main()
{
char texto[20];
texto = "Hola";
}
Es interesante saber cómo funciona una cadena por dentro, por eso vamos a ver primero
cómo se inicializa:
#include <stdio.h>
main()
{
char nombre[] = "Gandalf";
Resultado al ejecutar:
Texto: Gandalf
Tamaño de la cadena: 8 bytes
Curiosamente la respuesta nos dice que "Gandalf" ocupa 8 bytes. Como cada
elemento char ocupa un byte eso quiere decir que la cadena tiene 8 elementos, a pesar
de que "Gandalf" sólo cuenta con 7 letras. La razón de esta aparente paradoja estriba en
que la cadena tiene como carácter final el símbolo '\0', cuyo significado es "fin de cadena".
De esta forma, cuando queremos escribir la cadena basta con usar %sy el compilador
sabe cuántos elementos debe escribir: hasta que encuentre '\0'.
#include <stdio.h>
main()
{
char nombre[] = { 'G', 'a', 'n', 'd', 'a', 'l', 'f', '\0' };
Aquí ya se observa claramente que nombre tiene 8 elementos. Pero, ¿qué pasaría si no
pusiéramos '\0' al final?
#include <stdio.h>
main()
{
char nombre[] = { 'G', 'a', 'n', 'd', 'a', 'l', 'f' };
En mi ordenador se obtiene:
Texto: Gandalf-
Tamaño de la cadena: 7 bytes
Pero en otro después de "Gandalf" puede aparecer cualquier cosa. Lo que aquí sucede es
que printf no encuentra el símbolo '\0' y no sabe cuándo dejar de imprimir.
Afortunadamente, cuando introducimos una cadena se hace de la primera forma y el C se
encarga de poner el símbolo al final.
Es importante no olvidar que la longitud de una cadena es la longitud del texto más el
símbolo de fin de cadena. Por eso cuando definamos una cadena tenemos que reservarle
un espacio adicional. Por ejemplo:
strlen
strcpy
strcat
sprintf
strcmp
Para usar estas funciones en nuestro programa hay que añadir la directiva:
#include <string.h>
strlen
size_t *strlen(const char *cadena);
Esta función devuelve el número de caracteres que tiene la cadena (sin contar el '\0').
#include <stdio.h>
#include <string.h>
main()
{
char texto[]="Gandalf";
int longitud;
longitud = strlen(texto);
printf( "La cadena \"%s\" tiene %i caracteres.\n", texto, longitud );
}
main()
{
char texto[]="Gandalf";
char *p;
int longitud=0;
p = texto;
while (*p != '\0') {
longitud++;
printf( "%c\n", *p ); /* Mostramos la letra actual */
p++; /* Vamos a la siguiente letra */
}
printf( "La cadena \"%s\" tiene %i caracteres.\n", texto, longitud );
}
Para medir la longitud de la cadena usamos un puntero para recorrerla (el puntero p).
Hacemos que p apunte a texto. Luego entramos en un bucle while. La condición del bucle
comprueba si se ha llegado al fin de cadena ('\0'). Si no es así, suma 1 a longitud, muestra
la letra por pantalla e incrementa el puntero en 1 (con lo que pasamos a la siguiente
letra).
Copia el contenido de cadena2 en cadena1. cadena2 puede ser una variable o una
cadena directa (por ejemplo, "hola"). Debemos tener cuidado de que la cadena destino
(cadena1) tenga espacio suficiente para albergar a la cadena origen (cadena2).
#include <stdio.h>
#include <string.h>
main()
{
char texto[] = "Éste es un curso de C.";
char destino[50];
Vamos a ver otro ejemplo en el que la cadena destino es una cadena constante ("Éste es
un curso de C.") y no una variable. Además, en este ejemplo vemos que la cadena origen
es sustituida por la cadena destino totalmente. Si la cadena origen es más larga que la
destino, se eliminan las letras adicionales.
#include <stdio.h>
#include <string.h>
main()
{
char destino[50]="Éste no es un curso de HTML, sino de C.";
strcat
#include <stdio.h>
#include <string.h>
main()
{
char nombre_completo[50];
char nombre[]="Gandalf";
char apellido[]="el Gris";
Como siempre, tenemos asegurar que la variable en la que añadimos las demás cadenas
tenga el tamaño suficiente. Con la primera línea de este programa introducimos el nombre
en nombre_completo. Usamos strcpy para asegurarnos de que queda borrado cualquier
dato anterior. Luego usamos un strcat para añadir un espacio y, finalmente, introducimos
el apellido.
sprintf
int sprintf(char *destino, const char *format, ...);
#include <stdio.h>
#include <string.h>
main()
{
char nombre_completo[50];
char nombre[]="Gandalf";
char apellido[]="el Gris";
#include <stdio.h>
#include <string.h>
main()
{
char nombre1[]="Gandalf";
char nombre2[]="Frodo";
El resultado es:
Arrays de cadenas
Un array de cadenas puede servirnos para agrupar una serie de mensajes. Por ejemplo,
todos los mensajes de error de un programa. Luego, para acceder a cada mensaje, basta
con usar su número.
#include <stdio.h>
#include <string.h>
main()
{
error( 2 );
}
El resultado será:
#include <stdio.h>
#include <string.h>
#define ELEMENTOS 5
main()
{
char *dichos[ELEMENTOS] = {
"La avaricia rompe el saco",
"Más vale pájaro en mano que ciento volando",
"No por mucho madrugar amanece más temprano",
"Año de nieves, año de bienes",
"A caballo regalado no le mires el diente"
};
char *temp;
int i, j;
Para ver con mayor claridad el resultado a partir del desarrollo del proceso, se va a
sustituir cada cadena por su primera letra (menos la de "Año de nieves..." que se
sustituirá por Añ). Así, el proceso queda:
Las cadenas se pueden recorrer de igual forma que se hace con los arrays, usando
punteros. Vamos a ver un ejemplo: el siguiente sencillo programa cuenta los espacios y
las letras e (minúsculas) que hay en una cadena.
#include <stdio.h>
#include <string.h>
main()
{
char cadena[]="El puerto paralelo del PC";
char *p;
int espacios = 0, letras_e = 0;
p = cadena;
while (*p != '\0') {
if (*p == ' ') espacios++;
if (*p == 'e') letras_e++;
p++;
}
El resultado es:
Para recorrer la cadena necesitamos un puntero p que sea de tipo char. Debemos hacer
que p apunte a la cadena (p=cadena). Así, p apunta a la dirección del primer elemento de
la misma. El valor de *p sería, por tanto, 'E'. Comenzamos el bucle. La condición
comprueba que no se ha llegado al final de la cadena (*p != '\0'). Entonces se comprueba
si en la dirección a la que apunta p hay un espacio o una letra e. Si es así, se incrementan
las variables correspondientes. Una vez comprobado esto se pasa a la siguiente letra
(p++).
#include <stdio.h>
#include <string.h>
main()
{
char cadena[]="El puerto paralelo del PC";
char *p;
p = cadena;
while (*p != '\0') {
if (*p == ' ') *p = '-';
p++;
}
y se obtiene: