现在结构体写的是
struct point{
int x;
int y;}
从键盘上输入一个整数n,100>=n>=1 ,输n个横纵坐标,找距离原点最近的点输出,如果两点到原点距离相等的话,取横坐标小的点,如果横坐标也一样,就取纵坐标小的点输出格式为(横坐标,纵坐标)
#include<stdio.h>
#include<math.h>
struct point{ //定义坐标结构体
int x;
int y;
double s; //同时加上距离项,方便排序
};
int main(void)
{
int n; //n个候选点
scanf("%d",&n);
struct point poi[n];
struct point test; //调换顺序中间体(结构体允许整个结构赋值)
int i,j;
for(i=0;i<n;i++){
scanf("%d %d",&poi[i].x,&poi[i].y);
poi[i].s=poi[i].x*poi[i].x+poi[i].y*poi[i].y;
poi[i].s=pow(poi[i].s,0.5);
}
for(i=0;i<n;i++)
{
for(j=0;j<n-i-1;j++){
if(poi[j].s>poi[j+1].s) //根据s数据项进行排序
{
test=poi[j+1];
poi[j+1]=poi[j]; //首尾相接三行代码调换顺序
poi[j]=test;
}
}
}
printf("(%d,%d)",poi[0].x,poi[0].y); //输出排序第一,即s最小的点坐标
}