江湖救急,用C编程解决椭圆问题

图片说明

1个回答

这是一个没有完成问题的答案:
#include
#include
#include
void f(float x1,float x2,float y1,float y2,float a)
{
float f1f2,b,c,m,n,k,angle;
int i,j;
float p[100][2]
f1f2=sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));
c=f1f2/2;
if(c>=a)
printf("输入的数据不合理");
else
{
b=sqrt(a*a-c*c);
k=(y2-y1)/(x2-x1);
angle=atan(k);
m=(x1+x2)/2;
n=(y1+y2)/2;
for(i=0;i<50;i++)
{
x=(-a)+(i+1)*2*a/51;
yz=b*sqrt(1-x*x/a/a);
yf=-yz;
p[i][0]=(x+m)*cos(angle)+(yz+n)*sin(angle);
p[i][1]=(yz+n)*cos(angle)-(x+m)*sin(angle);
p[i+50][0]=(x+m)*cos(angle)+(yf+n)*sin(angle);
p[i+50][1]=(yf+n)*cos(angle)-(x+m)*sin(angle);
}
for(j=0;j<100;j++)
printf("(x%d,y%d)=(%f,%f)",j+1,j+1,p[j][0],p[j][1];
}
}
int main(void)
{
float x1,x2,y1,y2,a;
int i;
printf("请输入椭圆的焦点:(x1,y1),(x2,y2)和a值:");
scanf("%f%f%f%f%f",&x1,&x2,&y1,&y2,&a);
f(x1,x2,y1,y2,a);
system("pause");
return 0;
}
求教bug如何改,或者另给出一个,小弟感激不尽。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问
相关内容推荐