Cerința
Se dau coordonatele carteziene a n puncte în plan. Să se determine distanța maximă dintre un punct dat și originea sistemului de coordonate și numărul de puncte situate la acea distanță față de origine.
Date de intrare
Programul citește de la tastatură numărul n, iar apoi n perechi de puncte x y, reprezentând coordonatele punctelor.
Date de ieșire
Programul va afișa pe ecran două numere D C, reprezentând distanța maximă față de originea sistemului și numărul de puncte situate la acea distanță.
Restricții și precizări
1 ≤ n ≤ 100
coordonatele punctelor sunt numere întregi din intervalul [-1000,1000]
distanța maximă se va afișa cu cel puțin trei zecimale exacte
Răspunsuri la întrebare
Răspuns de
6
#include <iostream>
#include <cmath>
using namespace std;
struct Punct{
int x,y;
};
void Citire(Punct & P)
{
cin >> P.x >> P.y;
}
int pDistanta(Punct P)
{
return P.x * P.x + P.y * P.y;
}
int main()
{
int n , cnt , pMax = -1; // vom calcula patratul distantelor, nu distantele
Punct A;
cin >> n;
for(int i = 1 ; i <= n ; i ++)
{
Citire(A);
int pd = pDistanta(A);
if(pd > pMax)
pMax = pd, cnt = 1;
else
if(pd == pMax)
cnt ++;
}
cout << sqrt(pMax) << " " << cnt;
}
MariusIonescu:
Multumesc!
Alte întrebări interesante
Chimie,
8 ani în urmă
Matematică,
8 ani în urmă
Matematică,
8 ani în urmă
Matematică,
9 ani în urmă
Informatică,
9 ani în urmă