距离编程代码
‘壹’ 如何用c语言计算两点之间距离
用C语言计算两点之间距离的参考代码:
#include <stdio.h>
#include <stdlib.h>
#include "math.h"
typedef struct point {
double x;
double y;
}point;
point array[30001];
double distance(point a,point b);
int main(int argc, char *argv[])
{
while(1){
int n,i,j,count;
double maxdis,temp;
scanf("%d",&n);
for(i = 0;i<n;i++){
scanf("%f %f",&array[i].x,&array[i].y);
}
for(i = 0;i<n;i++){
//printf("%d %d ",array[i].x,array[i].y);
//printf("dis:%.2f ",distance(array[0],array[i]));
}
maxdis = 0.0;
for(i = 0;i<n;i++){
for(j = i;j<n;j++){
if(distance((array[i]),(array[j])) > maxdis ){
//printf("maxdis = :%.2f ",distance((array[i]),(array[j])));
maxdis =distance((array[i]),(array[j]));
}
}
}
printf("%.2f",maxdis);
}
system("pause");
return 0;
}
//计算x y之间距离
double distance(point a,point b){
return sqrt( (a.x - b.x)*(a.x - b.x) + (a.y -b.y)*(a.y -b.y) );
}
(1)距离编程代码扩展阅读:
C语言编写注意事项:
1、所有自定义变量必须声明才能使用。
2、每行只书写一条语句, 在运算符两边加上一个空格, 便于阅读。
3、整数除法将自动舍位, 不会进行四舍五入的操作。
4、for(初始化部分;条件部分;增长部分) - 比while 更适用于初始化和增长步长都是单条语句情况下。
5、使用#define 名字 替换文本 对部分"幻数" 赋予意义便于阅读 #define结尾不需要“;”号结束。
‘贰’ python编程题:编程求两点之间的曼哈顿距离
def My_abs(num):
if num < 0:
num *= -1
return num
print(abs(-5))
x1,y1=eval(input("输入A点坐标,以逗号分隔:"))
x2,y2=eval(input("输入B点坐标,以逗号分隔:"))
# 计算曼哈顿距离的函数
def getManhattanDistance(x1, y1, x2, y2):
return My_abs(x1 - x2) + My_abs(y1 - y2)
# 调用并输出计算的曼哈顿距离
print(getManhattanDistance(x1, y1, x2, y2))
abs在Python中有了,然后我就命名成了My_abs。
备注也都打好了。
折柳成荫写的是C,soulofbug写的是python
‘叁’ 卡西殴5800计算器方位角及距离编辑程序代码
设A点坐标(XA, YA),B点坐标(XB, YB),A点到B点距离l,A点到B点方位角aAB,则:
XB=XA+lcosaAB
YB=YA+lsinaAB
l=根号 (XB-XA)²+(YB-YA)²
当(YB-YA)≥0时,aAB=cos-1(XB-XA)/l
当(YB-YA)<0时,aAB=360- cos-1(XB-XA)/l
在卡西欧计算器中可以用“Rec”和“pol”功能键完成,方法如下:
正算Rec(l,aAB),显示X增量“I”,Y增量“J”
XB=XA+I,YB=YA+J
反算pol(XB-XA,YB-YA),显示距离l“I”,方位角aAB“J”,当J<0时J=J+360
‘肆’ 谁能提供,点到直线的距离公式 C语言程序
设点(x0,y0) ,直线为ax+by+c=0
则距离为fabs(ax0+by0+c)/sqrt(a*a+b*b)
前提是在文件前面加上#include <math.h>
‘伍’ 用C语言编写一个程序,求两点之间的距离
#include<stdio.h>
#include<math.h>
int main()
{
double x1,y1,x2,y2,distance;
printf("请输入第一个点的坐标:\nx1=");
scanf("%lf",&x1);
printf("y1=");
scanf("%lf",&y1);
printf("请输入第二个点的坐标:\nx2=");
scanf("%lf",&x2);
printf("y2=");
scanf("%lf",&y2);
distance=sqrt((x2-x1)*(x2-x1)+(y2-y1)*(y2-y1));
printf("这两点间的距离为:%lf\n",distance);
return 0;
}
‘陆’ 两数组最短距离 一道编程题解不出。。求思路或者代码
#include<iostream>
usingnamespacestd;
#defineM100
voidSearch()
{
intf[M],g[M],min[M][M],m,n;
cout<<"分别输入两数组的长度(100以内):"<<endl;
cin>>m>>n;
while(m<=0||m>M||n<=0||n>M)
{
cout<<"输入有误,重新输入:"<<endl;
cin>>m>>n;
}
inti,j,Min;
cout<<"输入数组f(长度为"<<m<<"):"<<endl;
for(i=0;i<m;i++)
cin>>f[i];
cout<<"输入数组g(长度为"<<n<<"):"<<endl;
for(i=0;i<n;i++)
cin>>g[i];
for(i=0;i<m;i++)
for(j=0;j<n;j++)
min[i][j]=(f[i]-g[j]>=0)?f[i]-g[j]:g[j]-f[i];
Min=min[0][0];
for(i=0;i<m;i++)
for(j=0;j<n;j++)
{
if(min[i][j]<Min)
Min=min[i][j];
}
cout<<"两数组的距离为:"<<Min<<endl;
}
intmain()
{
Search();
return0;
}
‘柒’ C语言编程问题:使用函数计算两点间的距离。
输入两点坐标(X1,Y1),(X2,Y2),计算并输出两点间的距离。
输入数据有多组,每组占一行,由4个实数组成,分别表示x1,y1,x2,y2,数据之间用空格隔开。
#include<stdio.h>
#include<math.h>
void main()
{
float x1,x2,y1,y2;
printf("请输入一组数据:");
while(~scanf("%f%f%f%f",&x1,&y1,&x2,&y2))//开始读取输入的数,知道文件结束。
{
printf("两点间的距离为:%.2f ",sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2)));
printf("请输入一组数据:");
}
}
(7)距离编程代码扩展阅读:
c语言基本运算
一:算术运算符
算术运算符非常地简单,就是小学数学里面的一些加减乘除操作。不过呢,还是有一些语法细节需要注意的。
一、加法运算符+
int a=10;
(此处空一行)
int b=a+5;
在第3行利用加法运算符+进行了加法运算,再将和赋值给了变量b,最终变量b的值是15
二、减法运算符或负值运算符-
int b=10-5;
(此处空一行)
int a=-10;
1、在第1行利用减法运算符-进行了减法运算,再将差赋值给了变量b,最终变量b的值是5
2、在第3行中,这个-并不是什么减法运算符,而算是一个负值运算符,-10代表的是负十
三、乘法运算符*
int b=10*5;
注意:乘法运算符并不是x或者X,而是星号*。变量b最终的值是50。
四、除法运算符/
double a=10.0/4;
double b=10/4;
(此处空一行)
printf("a=%f,b=%f ",a,b);
注意:除法运算符并不是÷,而是一个正斜杠/
‘捌’ 已知三十个地区的经纬度,用matlab怎么编程求出这三十个地区两两之间的距离,会的帮忙编下程序代码
直接用MATLAB地图工具箱(Mapping Toolbox)的distance函数就可以了,例如(为方便举例,这里只设置了4个点,30个点同样处理):
%已知各点的经纬度(依次为京沪津渝四地)
pts=[...
116.4639.92;
121.4831.22;
117.2039.13;
106.5429.59
];
%形成两两之间对应的矩阵(对称阵,可以只看上三角或下三角)
[LA1,LA2]=meshgrid(pts(:,2));
[LO1,LO2]=meshgrid(pts(:,1));
%计算两两之间的距离,单位为公里
R=distance(LA1,LO1,LA2,LO2,almanac('earth','wgs84'));
这里地球模型是采用的WGS84参考椭球,也可以改用其它参考椭球,具体可参考almanac函数。
得到的结果为
>>num2str(R,'%10.2f')
ans=
0.001066.68108.361460.16
1066.680.00959.951445.81
108.36959.950.001440.61
1460.161445.811440.610.00