1. 程式人生 > 其它 >csp202009-1 稱檢測點查詢

csp202009-1 稱檢測點查詢

技術標籤:csp演算法

csp202009-1 稱檢測點查詢

題目背景
2020 年 6 月 8 日,國務院聯防聯控機制釋出《關於加快推進新冠病毒核酸檢測的實施意見》,提出對“密切接觸者”等八類重點人群“應檢盡檢”,其他人群“願檢盡檢”。
問題描述
某市設有 n 個核酸檢測點,編號從 1 到 n,其中 i 號檢測點的位置可以表示為一個平面整數座標 (xi,yi)。
為方便預約核酸檢測,請根據市民所在位置 (X,Y),查詢距其最近的三個檢測點。
多個檢測點距離相同時,編號較小的視為更近。
輸入格式
輸入共 n+1 行。
第一行包含用空格分隔的三個整數 n、X 和 Y,表示檢測點總數和市民所在位置。

第二行到第 n+1 行依次輸入 n 個檢測點的座標。第 i+1 行(1≤i≤n)包含用空格分隔的兩個整數 xi 和 yi,表示 i 號檢測點所在位置。
輸出格式
輸出共三行,按距離從近到遠,依次輸出距離該市民最近的三個檢測點編號。
樣例輸入1
3 2 2
2 2
2 3
2 4
樣例輸出1
1
2
3
樣例輸入2
5 0 1
-1 0
0 0
1 0
0 2
-1 2
樣例輸出2
2
4
1
樣例2解釋
評測用例規模與約定
全部的測試點滿足,3≤n≤200,所有座標均為整數且絕對值不超過 1000。
提示
市民到第 i 號檢測點的距離 Di 可由如下公式算出:
在這裡插入圖片描述

#include<stdio.h>
#include
<math.h>
#include<algorithm> #include<limits.h> using namespace std; int main(){ int n,x,y,xi,yi,h,i=0,k; int a=INT_MAX,b=INT_MAX,c=INT_MAX,ans1=0,ans2=0,ans3=0; scanf("%d%d%d",&n,&x,&y);k=n; for(;i<n;i++){ scanf("%d%d",&xi,
&yi); h=(xi-x)*(xi-x)+(yi-y)*(yi-y); if(h<c){ if(h<b){ if(h<a){c=b;b=a;a=h;ans3=ans2;ans2=ans1;ans1=i+1;} else {c=b;b=h;ans3=ans2;ans2=i+1;} } else {c=h;ans3=i+1;} } } printf("%d\n%d\n%d\n",ans1,ans2,ans3); return 0; }

在其他地方看到的,感覺他寫的很好很簡單,記錄一下

#include <cstdio>
#include <algorithm>
using namespace std;
struct Station{
	int x;
	int y;
	int dis;
	int num;
};
bool cmp(Station s1, Station s2){
	if(s1.dis != s2.dis) return s1.dis < s2.dis;
	if(s1.num != s2.num) return s1.num < s2.num;
}
int main(){
	int n, locx, locy;
	scanf("%d %d %d", &n, &locx, &locy);
	
	Station s[n];
	for(int i=0; i<n; i++){
		scanf("%d %d", &s[i].x, &s[i].y);
		s[i].num = i + 1;
		s[i].dis = (s[i].x-locx)*(s[i].x-locx) + (s[i].y-locy)*(s[i].y-locy);
	}
	sort(s, s+n, cmp);
	for(int i=0; i<3; i++){
		printf("%d\n", s[i].num);
	}
	return 0;
}

注:
cmp函式的含義,如果返回值是 True,表示 要把 序列 (X,Y),X放Y前。
bool cmp(int &x,int &y){
  return x>y;//意味著x>y的時候,把x放到y前,按大到小排序。
}