Menú

Mostrar Mensajes

Esta sección te permite ver todos los mensajes escritos por este usuario. Ten en cuenta que sólo puedes ver los mensajes escritos en zonas a las que tienes acceso en este momento.

Mostrar Mensajes Menú

Mensajes - petit_cm

#1
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.




#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <math.h>

#define TAM 100

// Prototipos de las funciones
int leeIVector(int *v, int max);
int leeDVector(double *v, int max);
int leeIVector2(int *v, int max);
int leeDVector2(double *v, int max);
void escIVector(int *v, int l);
void escDVector(double *res,double *ress, int t);
void vertices(double *v, double *res, int t);
void vertices2(double *v, double *ress, int t);


//Funcion main
int main()
{
int l, v[100];
double vd[100];
double res[100];
double ress[100];
double x;


// Hacemos los mismo con el de reales
l = leeDVector2(vd, 100);

vertices(vd,res, l);

vertices2(vd,ress,1);

escDVector(res,ress,1);







// Nada puede ir mal
exit(EXIT_SUCCESS);
}

//Funcion para introducir datos
int leeDVector2(double *v, int max)
{
char aux[200];
int t;

printf("Introduce la coordenada x del punto:");
fgets(aux, TAM - 1, stdin);
v[0] = atof(aux);

printf("Introduce la coordenada y del punto:");
fgets(aux, TAM - 1, stdin);
v[1] = atof(aux);

printf("Introduce el radio:");
fgets(aux, TAM - 1, stdin);
v[2] = atof(aux);

printf("Introduce numero de lados:");
fgets(aux, TAM - 1, stdin);
t = atof(aux);


return t;
}

//Funcion calculo vertices

void vertices(double *v, double *res, int t){
int i;

double angulo;


double alpha;
alpha=360/ t;

double radian;
radian=180/3.1416;

double cos(double x);

for(i=0;i<t; i=i+1){

res[i]= v[0]+v[2]*cos(angulo/radian);

angulo=angulo +alpha;
}
}

void vertices2(double *v, double *ress, int t){
int i;

double angulo;


double alpha;
alpha=360/ t;

double radian;
radian=180/3.1416;

double sin(double x);

for(i=0;i<t; i=i+1){

ress[i]= v[0]+v[2]*sin(angulo/radian);

angulo=angulo +alpha;

}
}

//Imprimir

void escDVector(double *res,double *ress, int t)
{
int i;

printf("\n\nVector con %d elementos:\n\n", t);
for (i = 0; i < t; i++)
printf("Elemento %d: %lf %lf\n", i + 1, res[i],ress[i]);

puts("\n"); // Lineas en blanco para que sea mas legible
}


#2
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


void vertices(double *v, double *res, int t){
int i;

double angulo;
angul==0;

double alpha;
alpha==360/ t;

double radian;
radian=180/3.1416;

for(i=0;i<t; i=i+1){

res[i]= v[0]+v[2]*cos(angulo/radian);
angulo=angulo + alpha;

}
for(i=0;i<t; i=i+1){

res[i]= v[1]+v[2]*sin(angulo/radian);
angulo=angulo + alpha;

}

#3
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
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
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
Bueno trigonometria me defiendo, pero esta funcion si sabes hacerla te agradeceria muchisimo que me pasases el codigo.
Muchas graciaas
#7
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. "