Problemas con raíces.

Iniciado por KaizerPlazz, 11 Octubre 2016, 00:50 AM

0 Miembros y 3 Visitantes están viendo este tema.

KaizerPlazz

Hola soy nuevo tanto en el foro como programando y estoy siguiendo unos videos tutoriales (c/c++) en este video te explica como sacar la raíz cuadrada de un numero sin la librería math , pero no logro entenderlo ,  si entendí como sacarla con sqrt pero de este modo no . Alguien me podría orientar como funciona este código ? Gracias!

#include <stdio.h>
int main(){
printf("Calcular la raiz de un numero \n");
printf("Deme un numero: \n");
float num;
scanf("%f",&num);
float h = 0.00001 , raiz = h;
while(raiz*raiz < num){
raiz += h;
}
printf("\n%f",raiz);
return 0;
}




Mod: Los códigos deben ir en etiquetas GeSHi

engel lex

te recomiendo que coloques un printf a raíz dentro del ciclo...


ese es el metodo más simple, aunque menos eficientes más eficiente son con series de tailor... (aqui algo sobre eso)
El problema con la sociedad actualmente radica en que todos creen que tienen el derecho de tener una opinión, y que esa opinión sea validada por todos, cuando lo correcto es que todos tengan derecho a una opinión, siempre y cuando esa opinión pueda ser ignorada, cuestionada, e incluso ser sujeta a burla, particularmente cuando no tiene sentido alguno.

KaizerPlazz

#2
Gracias pero mi duda es que no entiendo el código que puse , si alguien me puede dar una explicación sobre este codigo , o sea quiero saber como funciona lo que puse.

#include <stdio.h>
int main(){
printf("Calcular la raiz de un numero \n");
printf("Deme un numero: \n");
float num;
scanf("%f",&num);
float h = 0.00001 , raiz = h;
while(raiz*raiz < num){
raiz += h;
printf("\n%f",raiz);
}
return 0;
}


Le agregue printf al ciclo n-n

oldaccount

#3
Hola KaizerPlazz.

Te dejo el código fuente limpio y explicado:

#include <stdio.h>

int main(){
float input = 0; // La entrada del usuario
float squareRoot = 0; // La raiz cuadrada que buscamos
float aux = 0.00001; // Cuanto más pequeño más precision en el resultado

scanf("%f", &input); //Leémos la entrada del usuario

/*
Si el valor almacenado en squareRoot multiplicado por sí mismo
no alcanza el valor de input, lo incrementamos un poco y repetimos
*/
while((squareRoot * squareRoot) < input) {
squareRoot = squareRoot + aux;
}

printf("%.4f\n", squareRoot); // Imprimir resultado con cuatro decimales

return 0;
}


Salida del programa:

2
1.4142


9
3.0000


163.281
12.7781


Saludos.

KaizerPlazz

Cita de: CRivasGomez en 11 Octubre 2016, 02:20 AM
Hola KaizerPlazz.

Te dejo el código fuente limpio y explicado:

#include <stdio.h>

int main(){
float input = 0; // La entrada del usuario
float squareRoot = 0; // La raiz cuadrada que buscamos
float aux = 0.00001; // Cuanto más pequeño más precision en el resultado

scanf("%f", &input); //Leémos la entrada del usuario

/*
Si el valor almacenado en squareRoot multiplicado por sí mismo
no alcanza el valor de input, lo incrementamos un poco y repetimos
*/
while((squareRoot * squareRoot) < input) {
squareRoot = squareRoot + aux;
}

printf("%.4f\n", squareRoot); // Imprimir resultado con cuatro decimales

return 0;
}


Salida del programa:

2
1.4142


9
3.0000


163.281
12.7781


Saludos.

Muchas gracias , pero el 0.00001 porque se pone? y de donde se saca el valor de la raiz o squareroot , yo se que tiene que ser menor que el numero , es que soy nuevo en esto.

engel lex

pon un printf en el click y verás como funciona, verás como el valor cambia hasta dar el resultado, ese 0.0001 es un valor que se le llama "epsilon" que en general es un "nivel de precisión"
El problema con la sociedad actualmente radica en que todos creen que tienen el derecho de tener una opinión, y que esa opinión sea validada por todos, cuando lo correcto es que todos tengan derecho a una opinión, siempre y cuando esa opinión pueda ser ignorada, cuestionada, e incluso ser sujeta a burla, particularmente cuando no tiene sentido alguno.

oldaccount

Cita de: KaizerPlazz en 11 Octubre 2016, 02:57 AM
Muchas gracias , pero el 0.00001 porque se pone? y de donde se saca el valor de la raiz o squareroot , yo se que tiene que ser menor que el numero , es que soy nuevo en esto.

Se prueba continuamente hasta llegar al resultado:

Primero se prueba si 0.00001 es la raíz cuadrada de input,
luego se prueba si 0.00002 es la raíz cuadrada de input,
luego se prueba si 0.00003 es la raíz cuadrada de input, etc.

Cada vez que se comprueba que squareRoot no es la raiz cuadrada de input, ((squareRoot * squareRoot) < input), se incrementa en 0.00001 y se vuelve a probar.

Simplemente se prueban todos los valores a partir del 0.00001 sucesivamente hasta detectar que se ha encontrado el que queremos.

Un ejemplo muy sencillo sería encontrar la raíz cuadrada del 9. Para ello podríamos comprobar si 1*1 es menor que 9 (sí lo es), si 2*2 es menor que 9 (sí lo es), si 3*3 es menor que 9 (no lo es). Como 3 es el primer número que hemos encontrado que al multiplicarlo por sí mismo no es menor que 9, ese es el resultado.

Saludos.

KaizerPlazz

Claro entonces como  siempre se cumple que squareroot es menor que input se sigue sumando y sumando pero como sabe el programa cuando tiene que parar?
Por ejemplo la raiz cuadrada de 5 es.. 2 o 2,23 (en el programa 2,2361)  Como sabe el programa que tiene que parar en el numero 2 ?  Gracias

engel lex

2*2 < 5? +=0.0001
2.0001*2.0001 < 5? +=0.0001
...
2.2361*2.2361 < 5? fin
El problema con la sociedad actualmente radica en que todos creen que tienen el derecho de tener una opinión, y que esa opinión sea validada por todos, cuando lo correcto es que todos tengan derecho a una opinión, siempre y cuando esa opinión pueda ser ignorada, cuestionada, e incluso ser sujeta a burla, particularmente cuando no tiene sentido alguno.

KaizerPlazz

Pero si 2*2 es 4 es menor que el input , pero aun asi el programa se detiene en 2 . Disculpe es que soy nuevo y es un quilombo esto xD  o yo soy muy duro :P