现在结构体写的是
struct point{
int x;
int y;}
从键盘上输入一个整数n,100>=n>=1 ,输n个横纵坐标,找距离原点最近的点输出,如果两点到原点距离相等的话,取横坐标小的点,如果横坐标也一样,就取纵坐标小的点输出格式为(横坐标,纵坐标)

C语言结构体,找坐标上距离原点最近的点
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
1条回答 默认 最新
关注
#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最小的点坐标 }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报