elhacker.net cabecera Bienvenido(a), Visitante. Por favor Ingresar o Registrarse
¿Perdiste tu email de activación?.

 

 


Tema destacado: AIO elhacker.NET 2021 Compilación herramientas análisis y desinfección malware


  Mostrar Mensajes
Páginas: 1 2 3 4 [5] 6 7 8 9 10 11 12 13
41  Programación / Programación C/C++ / Re: ejercicio en C en: 31 Octubre 2012, 13:13 pm
Lo bueno que tiene el código de rir3760 es que no hace ningún cambio en la cadena. Es genial.
42  Programación / Programación C/C++ / Re: ejercicio en C en: 31 Octubre 2012, 00:39 am
@xiruko: Me encanta.
43  Programación / Programación C/C++ / Re: ejercicio en C en: 31 Octubre 2012, 00:14 am
Me mola tu código leosansan.
Por cierto, ¿para que pones printf("\b")? ¿es por que te sale algún carácter raro?
Lo digo por que me suena que en algunas plataformas el carácter nulo es imprimible y tu codigo accede al ultimo caracter de la string (NULL) y lo imprime.
Yo  que estoy en linux, tu código imprime esto:
Código
  1. tuket@debian:~$ ./a.out
  2. hole
  3.  
  4.  
  5. hol
  6.  
  7. lho
  8.  
  9. olh

Parece que en linux no se imprime el carácter nulo entonces al borrar se queda con una letra menos. Tal vez el remedio sería no imprimir ese carácter para no tener que borrarlo.
Código
  1. k=strlen (cadena)-1;
  2. for (i=k;i<strlen (cadena);i++)
  3.  
.
Simplemente modificando esas dos líneas
44  Programación / Programación C/C++ / Re: Estructura incompleta. en: 30 Octubre 2012, 23:47 pm
Cuando haces typedef estas creando un nuevo tipo entonces no debes poner struct para declara una variable de ese tipo ni hacer un casting a ese tipo.
Es decir, puedes hacer:
Código
  1. typedef struct {
  2.    char cidade[20];
  3.    double datos[365];
  4.    int n_datos;
  5. }T_TEMP;
  6.  
  7.   T_TEMP *espacio;
  8.    espacio=(T_TEMP*)malloc(n*sizeof(T_TEMP));
  9.    return(*espacio);    //Que sepas que seguramente esto no es lo que realmente quieres hacer pero tampoco lo se si no veo el contexto
  10.  

Otra manera seria esta:

Código
  1. struct T_TEMP{
  2.    char cidade[20];
  3.    double datos[365];
  4.    int n_datos;
  5. };
  6.  
  7.    struct T_TEMP *espacio;
  8.    espacio=(struct T_TEMP*)malloc(n*sizeof(struct T_TEMP));
  9.    return(*espacio);
45  Programación / Programación C/C++ / Re: Duda con Programacion Modular en C en: 30 Octubre 2012, 23:31 pm
Una manera fácil de hacerlo es simplemente copiar y pegar dentro de las funciones(o módulos) que defines y pasar los parámetros por referencia(punteros):
Código
  1. #include <stdio.h>
  2. #include <string.h>
  3. #include <stdlib.h>
  4. #include <time.h>
  5. #include <math.h>
  6. #include <dos.h>
  7. #include "windows.h"
  8.  
  9. void jabon         (int *a, float *total, int n, float (*tabla)[2], int *seleccion);
  10. void afeitadora    (int *a, float *total, int n, float (*tabla)[2], int *seleccion);
  11. void shampoo       (int *a, float *total, int n, float (*tabla)[2], int *seleccion);
  12. void acondicionador(int *a, float *total, int n, float (*tabla)[2], int *seleccion);
  13. void pasta         (int *a, float *total, int n, float (*tabla)[2], int *seleccion);
  14.  
  15. int main (void){
  16.  
  17. float tabla [6][2] = {{1,5.00}, {2,3.50}, {3,7.45}, {4,8.32}, {5,4.50}, {6, 0}};
  18. int a , n, seleccion;
  19. float total;
  20.  
  21. do {
  22.  
  23. puts("\t\t\t*****Menu*****\n");
  24. printf("1. Jabon..............(c/u) %.2f Pesos" ,tabla[0][1]);
  25. printf("\n2. Afeitadora.........(c/u) %.2f Pesos", tabla[1][1]);
  26. printf("\n3. Shampoo............(c/u) %.2f Pesos", tabla[2][1]);
  27. printf("\n4. Acondicionador.....(c/u) %.2f Pesos", tabla[3][1]);
  28. printf("\n5. Pasta Dental.......(c/u) %.2f Pesos", tabla[4][1]);
  29. printf("\n6. Salir Del Sistema",tabla[5][1]);
  30. printf("\n \n Ingrese el numero del producto que desea adquirir: ");
  31. scanf("%d",&n);
  32.  
  33. switch(n)
  34. {
  35. case 1:
  36. jabon(&a, &total, n, tabla, &seleccion);
  37. break;
  38.  
  39. case 2:
  40. afeitadora(&a, &total, n, tabla, &seleccion);
  41. break;
  42.  
  43. case 3:
  44. shampoo(&a, &total, n, tabla, &seleccion);
  45. break;
  46.  
  47. case 4:
  48. acondicionador(&a, &total, n, tabla, &seleccion);
  49. break;
  50.  
  51. case 5:
  52. pasta(&a, &total, n, tabla, &seleccion);
  53. break;
  54.  
  55. case 6:
  56. system("cls");
  57. printf("\n***Gracias Por Usar Nuestros Servicios***\n");
  58. Sleep(800);
  59. break;
  60.  
  61. default:
  62. if(n<1 || n>6)
  63. {
  64. system("cls");
  65. puts("\n\n ***Opcion Invalida***\n\n");
  66. Sleep(500);
  67. }
  68.  
  69. break;
  70.  
  71. }
  72.  
  73. } while(seleccion!=2);
  74.  
  75. printf("\nTotal a pagar es: %.3f Pesos",total);
  76.  
  77. printf("\n\n\t");
  78. system("pause");
  79.  
  80. }  
  81.  
  82.  
  83. void jabon (int *a, float *total, int n, float (*tabla)[2], int *seleccion){
  84. printf("\n Cuantos Jabones desea adquirir? ");  
  85. scanf("%d",a);
  86.  
  87. *total= tabla[n - 1][1] * (*a) + (*total);
  88.  
  89. printf("\n Desea adquirir otro producto?");
  90. printf("\n\n1.Si 2.No: ");
  91. scanf("%d",seleccion);
  92. }
  93.  
  94. void afeitadora (int *a, float *total, int n, float (*tabla)[2], int *seleccion){
  95. printf("\n Cuantas Afeitadoras desea adquirir? ");
  96. scanf("%d",a);
  97.  
  98. *total= tabla[n - 1][1] * (*a) + (*total);
  99.  
  100. printf("\n Desea adquirir otro producto?");
  101. printf("\n\n 1.Si 2.No: ");
  102. scanf("%d",seleccion);
  103. }
  104.  
  105. void shampoo (int *a, float *total, int n, float (*tabla)[2], int *seleccion){
  106. printf("\n Cuantos Shampoos desea adquirir? ");
  107. scanf("%d",a);
  108.  
  109. *total= tabla[n - 1][1] * (*a) + (*total);
  110.  
  111. printf("\n Desea adquirir otro producto?");
  112. printf("\n\n1.Si 2.No: ");
  113. scanf("%d",seleccion);
  114. }
  115.  
  116. void acondicionador (int *a, float *total, int n, float (*tabla)[2], int *seleccion){
  117. printf("\n Cuantos Acondicionadores desea adquirir? ");
  118. scanf("%d",a);
  119.  
  120. *total= tabla[n - 1][1] * (*a) + (*total);
  121.  
  122. printf("\n Desea adquirir otro producto?");
  123. printf("\n\n1.Si 2.No: ");
  124. scanf("%d",seleccion);
  125. }
  126.  
  127. void pasta (int *a, float *total, int n, float (*tabla)[2], int *seleccion){
  128. printf("\n Cuantas Pasta Dental desea aquirir? ");
  129. scanf("%d",a);
  130.  
  131. *total= tabla[n - 1][1] * (*a) + (*total);
  132.  
  133. printf("\n Desea adquirir otro producto?");
  134. printf("\n\n1.Si 2.No: ");
  135. scanf("%d",seleccion);
  136. }

De verdad que es muy fácil si sabes como.
Por cierto, ¿el código lo ha hecho tu profesora? Hay un error el la linea esta "total= tabla[n - 1][1] * a;"
Si quieres comprar jabones después de comprar lo que sea sólo pagaras los jabones. Lo correcto sería "total= tabla[n - 1][1] * a+ total;" o "total+= tabla[n - 1][1] * a;"
46  Programación / Programación C/C++ / Re: ejercicio en C en: 30 Octubre 2012, 21:03 pm
Así es como yo lo haría.

Código
  1. #include <stdio.h>
  2.  
  3. int cnoc(char*);
  4. void rotate(char*);
  5.  
  6. int main(){
  7. char cad[256]={};
  8. scanf("%s",cad);
  9. printf("length=%20s\n", cad); //NOTA: cuidado con el buffer overflow(printf("length=%s\n", cad);)
  10. int n=cnoc(cad);
  11.  
  12.  
  13. int i;
  14. for(i=0; i<n; i++){ //rotar n veces. Así conseguimos todas las combinaciones posibles
  15. rotate(cad);
  16. printf("%s\n", cad);
  17. }
  18. }
  19.  
  20.  
  21. int cnoc(char cad[]){  // Devuelve el número de caracteres en una cadena
  22. int i=0;
  23. while(cad[i]) i++;
  24. return i;
  25. }
  26.  
  27. void rotate(char cad[]){ //rotar la cadena 1 posición
  28. int n=cnoc(cad)-1; //n apunta a la untima posición
  29. char last= cad[n--]; //guardamos el valor de la ultima posición en variable last
  30. for(;n>=0;n--) cad[n+1]=cad[n]; //desplazamos todos los caracteres una posición hacia delante
  31. cad[0]=last; //como el primer elemento no tiene precedente tenemos que==>
  32. // ==>poner en él el que fue el el último
  33. }
EDIT: añado comentarios
47  Seguridad Informática / Hacking / Re: ALGORITMO DE PROGRAMA A PARTIR DE CLAVE VÁLIDA (DUDA) en: 16 Junio 2012, 00:42 am
Hay ciertos programas comerciales, que al instalar te da un código y con ese código el proveedor te da la clave necesaria para instalar el programa. En estos casos si que se puede y no es tan difícil, por que el programa ejecuta un algoritmo a partir del código. Mi hermano tenia un programa que compro con el cual durante la instalación te da un código. Con este código llamas por teléfono a la empresa de software y te da la clave. Cada ordenador genera un código propio. Con lo cual solo puedes pedir la clave una vez (por que ellos se apuntan que código de producto les ha llamado para pedir la clave)para que no lo instales en varios ordenadores. Lo que le sucedió a mi hermano es que formateo el ordenador y el código era diferente entonces no podia instalarlo por que ya había llamado una vez. Con el ollydbg le conseguí sacar la clave y el algoritmo que usaba. Si es este tu caso te puedo ayudar...
48  Seguridad Informática / Hacking / Re: Criptoanalizar ¿Por dónde empezar? en: 16 Junio 2012, 00:14 am
El camino que sigues es bueno, ir descartando. La verdad es que no siempre puedes descartar tantos como para quedarte con uno. Sin embargo, cuando te quedas con con 7 u 8 por ejemplo, lo que puedes hacer es intentar descifrar asumiendo que se ha usado el algoritmo más fácil de criptoanalizar(sobre todo los algoritmos inyectivos, osea que dado un mensaje cifrado solo existe un posible descirado, por que suelen ser mas eficientes de calcular). Si no se consigue con ninguno de estos algoritmos "faciles de des cifrar", puedes pasar a los difíciles (no inyectivo(aunque no necesariamente)) como md5 etc...
El descifrado de un md5 puede ser muy difícil ya que solo se puede con diccionarios y fuerza bruta. Y aun así no tienes certeza de que sea el algoritmo usado(siempre es posible que el algoritmo que se ha usado no lo conoces o que sea un algoritmo secreto), ni de que habiendo sido exitoso el descifrado del mensaje hayas obtenido el mensaje original por que varios mensajes al encriptarlos pueden tener una misma imagen.
En todo caso si durante el proceso llegas a algo que tiene sentido(por ejemplo usas un diccionario y te da que el mensaje descifrado es "soy un tio molon") puedes estar suguro al 99.99999% de que has descifrado el mensaje y conoces el algoritmo que se ha usado, pero sin embargo si al descifrar un mensaje que es por ejemplo un correo electrónico llegas a algo como "g5Tujnd7%6"@3tººªx" puedes estar seguro al 0.001% de que eso no es el mensaje ya que no es lo que se diga muy frecuente en un correo electrónico. De todas maneras depende del contexto.
Quiero decir, hay veces que un mensaje puedes descifrarlo y otras veces no...
49  Seguridad Informática / Hacking / Re: backtrack 5 manual? en: 11 Junio 2012, 20:33 pm
Comparto opinión, con el señor Martin teletubi.
50  Seguridad Informática / Hacking / Re: backtrack 5 manual? en: 10 Junio 2012, 12:55 pm
Hola. He encontrado esto: http://www.dragonjar.org/curso-backtrack-5-en-espanol.xhtml
Páginas: 1 2 3 4 [5] 6 7 8 9 10 11 12 13
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines