#1058
Puncte1
Andrei se descurcă foarte bine la geometrie şi de aceea născoceşte tot felul de jocuri pe care le testează cu Alexandru, colegul său de bancă. Pentru a pregăti noul joc cu trei niveluri, Andrei desenează pe o foaie de matematică reperul cartezian xOy
şi mai multe puncte distincte. Fiecare punct desenat are atât abscisa x
, cât şi ordonata y
, numere întregi.
La primul nivel, Alexandru determină numărul maxim de puncte (dintre cele desenate) aflate pe una dintre axele sistemului cartezian sau pe o dreaptă paralelă cu una dintre cele două axe.
La al doilea nivel, Alexandru consideră toate punctele desenate a căror abscisă x
şi ordonată y
verifică cel puţin una dintre relaţiile x=y
sau x+y=0
şi apoi calculează câte drepte distincte trec prin cel puţin două dintre aceste puncte.
La al treilea nivel, Alexandru numără şi şterge punctele din 3
în 3
(primul, al 4
-lea, al 7
-lea etc.), începând cu cel mai din stânga punct desenat şi continuând către dreapta. Dacă două sau mai multe puncte au aceeaşi abscisă, el le numără pe acestea de jos în sus (începând de la punctul cu ordonata cea mai mică). Când a ajuns cu număratul la cel mai din dreapta punct continuă cu cel mai din stânga punct rămas.
Alexandru se opreşte cu numărarea şi ştergerea când rămâne un singur punct desenat pe foaie.
Scrieţi un program care citeşte numărul natural nenul N
, apoi cele 2*N
numere întregi ce reprezintă coordonatele celor N
puncte şi determină:
a) NRP
, numărul maxim de puncte (dintre cele desenate) aflate pe una dintre axele sistemului cartezian sau pe o dreaptă paralelă cu una dintre cele două axe;
b) NRD
, numărul de drepte distincte care trec prin cel puţin două dintre punctele desenate a căror abscisa x
şi ordonată y
verifică cel puţin una dintre relaţiile x=y
sau x+y=0
;
c) XP
reprezentând abscisa punctului rămas pe foaie la sfârşitul celui de-al treilea nivel al jocului.
Problema | Puncte1 | Operații I/O |
puncte1.in /puncte1.out
|
---|---|---|---|
Limita timp | 0.8 secunde | Limita memorie |
Total: 32 MB
/
Stivă 32 MB
|
Id soluție | #52956087 | Utilizator | |
Fișier | puncte1.cpp | Dimensiune | 1.35 KB |
Data încărcării | 14 Octombrie 2024, 10:39 | Scor / rezultat | 35 puncte |
puncte1.cpp: In function 'int main()': puncte1.cpp:29:27: warning: narrowing conversion of 'x' from 'int' to 'short int' inside { } [-Wnarrowing] v.push_back({x, y}); ^ puncte1.cpp:29:27: warning: narrowing conversion of 'y' from 'int' to 'short int' inside { } [-Wnarrowing]
Test | Timp | Mesaj evaluare | Scor posibil | Scor obținut | ||
---|---|---|---|---|---|---|
1 | 0 secunde | Cerinta a - corect. Cerinta b - corect. Cerinta c - corect. | 5 | 5 | ||
2 | 0 secunde | Cerinta a - corect. Cerinta b - corect. Cerinta c - corect. | 5 | 5 | ||
3 | 0 secunde | Cerinta a - corect. Cerinta b - corect. Cerinta c - corect. | 5 | 5 | ||
4 | 0 secunde | Cerinta a - corect. Cerinta b - corect. Cerinta c - corect. | 5 | 5 | ||
5 | 0.048 secunde | Cerinta a - corect. Cerinta b - corect. Cerinta c - corect. | 5 | 5 | ||
6 | 0.2 secunde | Cerinta a - corect. Cerinta b - corect. Cerinta c - corect. | 5 | 5 | ||
7 | 0 secunde | Cerinta a - corect. Cerinta b - corect. Cerinta c - corect. | 5 | 5 | ||
8 | Depășit | Limita de timp depășită | 5 | 0 | ||
9 | Depășit | Limita de timp depășită | 5 | 0 | ||
10 | Depășit | Limita de timp depășită | 5 | 0 | ||
11 | Depășit | Limita de timp depășită | 5 | 0 | ||
12 | Depășit | Limita de timp depășită | 5 | 0 | ||
13 | Depășit | Limita de timp depășită | 5 | 0 | ||
14 | Depășit | Limita de timp depășită | 5 | 0 | ||
15 | Depășit | Limita de timp depășită | 5 | 0 | ||
16 | Depășit | Limita de timp depășită | 5 | 0 | ||
17 | Depășit | Limita de timp depășită | 5 | 0 | ||
18 | Depășit | Limita de timp depășită | 5 | 0 | ||
19 | Depășit | Limita de timp depășită | 5 | 0 | ||
20 | Depășit | Limita de timp depășită | 5 | 0 | ||
Punctaj total | 35 |
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema Puncte1 face parte din prima categorie. Soluția propusă de tine va fi evaluată astfel:
Suma punctajelor acordate pe testele utilizate pentru verificare este 100. Astfel, soluția ta poate obține cel mult 100 de puncte, caz în care se poate considera corectă.