Horizontal

martes, 5 de mayo de 2015

Uso de la función memchr

Archivo de cabecera / Librería:
 string
Declaración:
#include<string.h>
void *memchr(const void *s,int c,size_t n);
Ejemplo:
#include<stdio.h>
#include<string.h>

int main(){
    char s[]="programas en c";
    char *t=memchr(s,'e',strlen(s));
    printf("es --> %s\n",t);
    return 0;
}
Salida:
 es --> en c

Uso de la función string ( )

jueves, 31 de julio de 2014

Uso de la función strcpy


Archivo de cabecera / Librería:
 string.h

Declaración:
 char *strcpy ( char *destino , const char *fuente );

Parámetros:
 destino
  Cadena que almacenará una copia de 'fuente'.
 fuente
  Cadena que se copiará.

Valor de retorno:
 Se retorna la cadena 'destino'.

Ejemplo:
#include<stdio.h>
#include<string.h>
int main(){
    char fuente[100]="hola mundo";
    char destino1[100],destino2[100];
    char *retorno1,*retorno2;

    retorno1=strcpy(destino1,fuente);
    retorno2=strcpy(destino2,"cadena a copiar");

    printf("fuente:   %s\n",fuente);
    printf("destino1: %s\n",destino1);
    printf("retorno1: %s\n",retorno1);
    printf("destino2: %s\n",destino2);
    printf("retorno2: %s\n",retorno2);
    return 0;
}

Salida:
 fuente:   hola mundo
 destino1: hola mundo
 retorno1: hola mundo
 destino2: cadena a copiar
 retorno2: cadena a copiar

Implementación alternativa:
#include<stdio.h>
char *mi_strcpy(char *destino,char *fuente){
    int i;
    for(i=0;fuente[i]!='\0';i++)destino[i]=fuente[i];
    destino[i]='\0';
    return destino;
}
int main(){
    char fuente[100]="hola mundo";
    char destino1[100],destino2[100];
    char *retorno1,*retorno2;

    retorno1=mi_strcpy(destino1,fuente);
    retorno2=mi_strcpy(destino2,"cadena a copiar");

    printf("fuente:   %s\n",fuente);
    printf("destino1: %s\n",destino1);
    printf("retorno1: %s\n",retorno1);
    printf("destino2: %s\n",destino2);
    printf("retorno2: %s\n",retorno2);
    return 0;
}

Salida:
 fuente:   hola mundo
 destino1: hola mundo
 retorno1: hola mundo
 destino2: cadena a copiar
 retorno2: cadena a copiar

Uso de la función strcpy ( )

sábado, 21 de junio de 2014

Ordenamiento por intercambio - Burbuja

 Este algoritmo de ordenación realiza comparaciones sucesivas entre elementos adyacentes  comparando a los valores a[i] y a[i+1]. Finalizando con un ordenamiento de menor a mayor.

 Función para ordenamiento burbuja


  1. void burbuja(int *vector,int n){
  2. int i,j;
  3. for(i=1;i<n;i++)
  4. for(j=0;j<n-i;j++)
  5. if(vector[j]>vector[j+1]){
  6. int aux=vector[j];
  7. vector[j]=vector[j+1];
  8. vector[j+1]=aux;
  9. }
  10. }


Código


  1. #include<stdio.h>
  2. void burbuja(int *vector,int n){
  3. int i,j;
  4. for(i=1;i<n;i++)
  5. for(j=0;j<n-i;j++)
  6. if(vector[j]>vector[j+1]){
  7. int aux=vector[j];
  8. vector[j]=vector[j+1];
  9. vector[j+1]=aux;
  10. }
  11. }
  12. int main(){
  13. int i,j,n;
  14. int vector[1000];
  15. printf("ingrese la cantidad\n");
  16. scanf("%d",&n);
  17. printf("ingrese los valores\n");
  18. for(i=0;i<n;i++)
  19. scanf("%d",&vector[i]);
  20. //se ordena
  21. burbuja(vector,n);
  22. //ver ordenacion
  23. printf("ordenamiento por intercambio ( Burbuja )\n");
  24. for(i=0;i<n;i++)
  25. printf("%d ",vector[i]);
  26. printf("\n");
  27. return 0;
  28. }
Ejemplo de salida:
 ejemplo - ordenamiento por intercambio ( Burbuja )

domingo, 30 de marzo de 2014

Uso de la función strlen

Archivo de cabecera / Librería:
 string.h

Declaración:
 size_t strlen ( const char *string );

Parámetros:
 string
  La cadena a procesar.

Valor de retorno:
 Longitud de la cadena.

Ejemplo:
#include<stdio.h>
#include<string.h>
int main(){
    char string[100];
    printf("Ingrese el string: ");
    scanf("%s",string);
    int tam=strlen(string);
    printf("Su longitud es : %d\n",tam);
    return 0;
}

Salida:
 Ingrese el string: algoritmos
 Su longitud es : 10

Implementación alternativa:
#include<stdio.h>
int mi_strlen(char *string){
    int i;
    for(i=0;string[i]!='\0';i++);
    return i;
}
int main(){
    char string[100];
    printf("Ingrese el string: ");
    scanf("%s",string);
    int tam=mi_strlen(string);
    printf("Su longitud es : %d\n",tam);
    return 0;
}

Salida:
 Ingrese el string: algoritmos
 Su longitud es : 10

Uso de la función strlen ( )

domingo, 2 de junio de 2013

Relacionando char con int

Relacionando char con int

 La idea de esta relación es pues que podemos imprimir un char dado un entero y viceversa

 Por ejemplo el siguiente programa muestra los char que son generados por enteros:

  1. #include<stdio.h>
  2. int main(){
  3.     int i;
  4.     for(i=0;i<128;i++)
  5.         printf("%c ",i);
  6.    
  7. }

  El cual nos da el siguiente resultado:
      ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~ 


 Con la misma ideal imprimimos números:



  1. #include<stdio.h>
  2. int main(){
  3.     char c='a';
  4.     printf("%c en entero es %d",c,c);
  5. }


 También podemos hacer:

  1. #include<stdio.h>
  2. int main(){
  3.     int i;
  4.     char c;
  5.     i=97;
  6.     c=i;
  7.    
  8.     printf("i de valor %d",i);
  9.     printf("\nc de valor %c",c);
  10. }

lunes, 4 de marzo de 2013

Terna Pitagórica

 El muy conocido teorema de Pitagóricas básicamente manifiesta que en un triángulo rectángulo la suma de los cuadrados de los catetos es igual al cuadrado de la hipotenusa, así decimos que una terna pitagórica es una tupla de tres números naturales que cumples dicho teorema.

Si queremos hallar todas las tuplas menores a un número "n", lo podemos hacer usando la búsqueda exhaustiva o fuerza bruta.

  La siguiente función imprime todas las ternas Pitagóricas menores a "n" y regresa la cantidad de ternas.


int terna(int n){
    int i,j,k,cont;
    cont=0;
    for(i=1;i<=n;i++)
        for(j=1;j<=n;j++)
            for(k=1;k<=n;k++)
                if(i*i==j*j+k*k){
                    printf("( %d , %d , %d )\n",j,k,i);
                    cont++;
                }
    return cont;
}


En este caso el programa halla ternas menores a 200

  1. //Terna Pitagorica
  2. #include<stdio.h>
  3. int terna(int n){
  4.     int i,j,k,cont;
  5.     cont=0;
  6.     for(i=1;i<=n;i++)
  7.         for(j=1;j<=n;j++)
  8.             for(k=1;k<=n;k++)
  9.                 if(i*i==j*j+k*k){
  10.                     printf("( %d , %d , %d )\n",j,k,i);
  11.                     cont++;
  12.                 }
  13.     return cont;
  14. }
  15. int main(){
  16.     int n,cantidad;
  17.     n=200;
  18.     cantidad=terna(n);
  19.     printf("existen %d ternas menores a %d ",cantidad,n);
  20.     return 0;
  21. }

miércoles, 2 de enero de 2013

Factorizar un número

   Al factorizar un número de busca obtener sus factores primos, en el siguiente programa se divide el número ingresado(n), por los números 2,3,4,5... hasta n, no es necesario obtener el número primo para realizar la división, pues siempre se encuentra primero al número primo, que luego se divide.

CÓDIGO

  1.  //Factorizar un numero
  2. #include<stdio.h>
  3. int main(){
  4.     int n,i,j;
  5.     int a[50];   
  6.       //pedimos un numero positivo
  7.     printf("ingrese el numero:\n");
  8.     scanf("%d",&n);
  9.     while(n<=0)
  10.     {
  11.        printf("el numero debe ser positivo:\n");
  12.        scanf("%d",&n);
  13.     }   
  14.       //obtenemos los factores
  15.     i=2;
  16.     j=0;
  17.     while(n>1)
  18.     {
  19.        if(n%i==0)
  20.        {
  21.           n=n/i;
  22.           a[j]=i;
  23.           j++;
  24.           i=2;
  25.        }
  26.        else
  27.           i++;
  28.     }   
  29.       //imprimir los factores
  30.     for(i=0;i<j;i++)
  31.        printf("\nfactor %d = %d",i+1,a[i]);
  32.     
  33.     getchar();
  34.     return 0;
  35. }
Related Posts Plugin for WordPress, Blogger...