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

 

 


Tema destacado: Usando Git para manipular el directorio de trabajo, el índice y commits (segunda parte)


  Mostrar Mensajes
Páginas: [1]
1  Programación / Programación C/C++ / Re: Ayuda para resolver el programa en: 30 Marzo 2017, 22:52 pm
Mi programa es este, consigo obtener un vertice, pero los valores x e y de este no son correctos y no consigo que muestre en pantalla todos los vertices, solo muestra uno, el primero. Hasta la linia 75 funciona correctamente.  A partir de ahi no se obtiene el resultado deseado.

Código
  1.  
  2.  
  3. #include <stdio.h>
  4. #include <stdlib.h>
  5. #include <string.h>
  6. #include <math.h>
  7.  
  8. #define TAM 100
  9.  
  10. // Prototipos de las funciones
  11. int leeIVector(int *v, int max);
  12. int leeDVector(double *v, int max);
  13. int leeIVector2(int *v, int max);
  14. int leeDVector2(double *v, int max);
  15. void escIVector(int *v, int l);
  16. void escDVector(double *res,double *ress, int t);
  17. void vertices(double *v, double *res, int t);
  18. void vertices2(double *v, double *ress, int t);
  19.  
  20.  
  21. //Funcion main
  22. int main()
  23. {
  24. int l, v[100];
  25. double vd[100];
  26. double res[100];
  27. double ress[100];
  28. double x;
  29.  
  30.  
  31. // Hacemos los mismo con el de reales
  32. l = leeDVector2(vd, 100);
  33.  
  34. vertices(vd,res, l);
  35.  
  36. vertices2(vd,ress,1);
  37.  
  38. escDVector(res,ress,1);
  39.  
  40.  
  41.  
  42.  
  43.  
  44.  
  45.  
  46. // Nada puede ir mal
  47. exit(EXIT_SUCCESS);
  48. }
  49.  
  50. //Funcion para introducir datos
  51. int leeDVector2(double *v, int max)
  52. {
  53. char aux[200];
  54. int t;
  55.  
  56. printf("Introduce la coordenada x del punto:");
  57. fgets(aux, TAM - 1, stdin);
  58. v[0] = atof(aux);
  59.  
  60. printf("Introduce la coordenada y del punto:");
  61. fgets(aux, TAM - 1, stdin);
  62. v[1] = atof(aux);
  63.  
  64. printf("Introduce el radio:");
  65. fgets(aux, TAM - 1, stdin);
  66. v[2] = atof(aux);
  67.  
  68. printf("Introduce numero de lados:");
  69. fgets(aux, TAM - 1, stdin);
  70. t = atof(aux);
  71.  
  72.  
  73. return t;
  74. }
  75.  
  76. //Funcion calculo vertices
  77.  
  78. void vertices(double *v, double *res, int t){
  79. int i;
  80.  
  81. double angulo;
  82.  
  83.  
  84. double alpha;
  85. alpha=360/ t;
  86.  
  87. double radian;
  88. radian=180/3.1416;
  89.  
  90. double cos(double x);
  91.  
  92. for(i=0;i<t; i=i+1){
  93.  
  94. res[i]= v[0]+v[2]*cos(angulo/radian);
  95.  
  96. angulo=angulo +alpha;
  97. }
  98. }
  99.  
  100. void vertices2(double *v, double *ress, int t){
  101. int i;
  102.  
  103. double angulo;
  104.  
  105.  
  106. double alpha;
  107. alpha=360/ t;
  108.  
  109. double radian;
  110. radian=180/3.1416;
  111.  
  112. double sin(double x);
  113.  
  114. for(i=0;i<t; i=i+1){
  115.  
  116. ress[i]= v[0]+v[2]*sin(angulo/radian);
  117.  
  118. angulo=angulo +alpha;
  119.  
  120. }
  121. }
  122.  
  123. //Imprimir
  124.  
  125. void escDVector(double *res,double *ress, int t)
  126. {
  127. int i;
  128.  
  129. printf("\n\nVector con %d elementos:\n\n", t);
  130. for (i = 0; i < t; i++)
  131. printf("Elemento %d: %lf %lf\n", i + 1, res[i],ress[i]);
  132.  
  133. puts("\n"); // Lineas en blanco para que sea mas legible
  134. }
  135.  
  136.  
  137.  
2  Programación / Programación C/C++ / Re: Ayuda para resolver el programa en: 30 Marzo 2017, 17:00 pm
He hecho esta función para calcular la coordenadas x e y de los vértices, pero no funciona y se que no esta bien hecha, me podéis ayudar a corregir los errores o decirme lo que falte? Muchas gracias

v[0]  es la coordenada x del centro, v[1]  es la coordenada y del centro, v[2] el radio y t el numero de lados.
Programa hecho en lenguaje C

Código
  1. void vertices(double *v, double *res, int t){
  2. int i;
  3.  
  4. double angulo;
  5. angul==0;
  6.  
  7. double alpha;
  8. alpha==360/ t;
  9.  
  10. double radian;
  11. radian=180/3.1416;
  12.  
  13. for(i=0;i<t; i=i+1){
  14.  
  15. res[i]= v[0]+v[2]*cos(angulo/radian);
  16. angulo=angulo + alpha;
  17.  
  18. }
  19. for(i=0;i<t; i=i+1){
  20.  
  21. res[i]= v[1]+v[2]*sin(angulo/radian);
  22. angulo=angulo + alpha;
  23.  
  24. }
  25.  
  26.  
3  Programación / Programación C/C++ / Re: Ayuda para resolver el programa en: 27 Marzo 2017, 20:43 pm
Esto seria correcto para obtener las posiciones cartesianas x e y de cada vertice del poligono en un plano?

alpha = 360 / cantidad de lados del poligono
radian = 180/PI 
xc + radio*cos(angulo/radian)
yc + radio*sin(angulo/radian)
angulo = angulo+alpha
4  Programación / Programación C/C++ / Re: Ayuda para resolver el programa en: 27 Marzo 2017, 20:32 pm
Como obtener la posición del vértice a partir del radio, número de lados y el centro. No se como plantear la ecuación que me de como resultado esa posición.
5  Programación / Programación C/C++ / Re: Ayuda para resolver el programa en: 27 Marzo 2017, 20:27 pm
La principal duda que tengo es la función matemática para calcular la posición de los vertices a partir de el centro, el radio y el número de lados. Si me podeis ayudar a obtenerla, a partir de ahi puedo empezar a trabajar.
6  Programación / Programación C/C++ / Re: Ayuda para resolver el programa en: 26 Marzo 2017, 18:09 pm
Bueno trigonometria me defiendo, pero esta funcion si sabes hacerla te agradeceria muchisimo que me pasases el codigo.
Muchas graciaas
7  Programación / Programación C/C++ / Ayuda para resolver el programa en: 26 Marzo 2017, 13:14 pm
Por favor, alguien podría ayudarme a realizar un código C que resuelva el siguiente problema? Necesito vuestra ayuda

"Realiza una función que, dado un punto en el plano, un radio y un número de lados, devuelva un vector con los vértices de un polígono regular con tales lados y radio, centrado en el punto dado. "
Páginas: [1]
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines