Constructorii angajaţi de faraonul Keops au terminat construirea piramidei în trepte mult visată. Măreaţa piramidă are n
camere identice de formă cubică, numerotate de la 1
la n
, dispuse pe m
niveluri astfel:
- camera din vârful piramidei formează nivelul
1
şi are numărul1
; - nivelul
2
al piramidei este format din următoarele4
camere care în secţiune cu un plan paralel cu baza au aspectul unei matrice cu2
linii şi2
coloane; camerele de pe nivelul2
sunt numerotate de la2
la5
în ordinea crescătoare a liniilor matricei, iar pe aceeaşi linie în ordinea crescătoare a coloanelor matricei;
……………….. - nivelul
m
al piramidei este format dinm*m
camere şi au, în secţiune cu un plan paralel cu baza, aspectul unei matrice cum
linii şi m coloane; camerele de pe nivelulm
sunt numerotate în continuarea celor de pe nivelurile1
,2
,…,m-1
, în ordinea crescătoare a liniilor matricei de secţiune, iar pe aceeaşi linie în ordinea crescătoare a coloanelor matricei. De exemplu, piramida din desenul de mai sus aren=30
,m=4
iar camerele sunt numerotate şi dispuse pe niveluri astfel:
Nivelurile de camere sunt poziţionate astfel încât camerele de pe prima linie şi prima coloană a fiecărui nivel să se suprapună. Pentru exemplul dat, camerele 1
, 2
, 6
şi 15
sunt situate una sub alta, în această ordine.
Accesul în oricare din camerele piramidei, situate pe diferite niveluri, se realizează prin drumuri construite astfel:
- intrarea în piramidă se face doar prin camera din vârful ei, cea cu numărul
1
; - din camera cu numărul
k
de pe un drum se poate intra într-una din cele patru camere situate pe nivelul imediat următor al piramidei şi anume: camera situată sub cea cu numărulk
sau una din cele trei camere vecine acesteia în secţiune (în direcţiile Est, Sud-Est, Sud, considerând secţiunile poziţionate ca în imaginile de mai sus). De exemplu, din camera cu numărul10
se poate intra într-una din camerele cu numerele:20
,21
,24
sau25
.
Faraonul priveşte cu mândrie şi tristeţe la frumoasa piramidă. Banii din visterie s-au împuţinat iar camerele piramidei trebuie finisate şi decorate. Scribul său favorit a refăcut toate calculele, a eliminat obiectele inutile şi a stabilit pentru fiecare cameră k
un cost c
k
aferent finisării şi decorării ei (1≤k≤n
).
Însă, suma totală necesară fiind încă mare, faraonul i-a cerut scribului să aleagă un drum, dintre cele construite, care să treacă prin toate nivelurile piramidei astfel încât suma s
a tuturor costurilor aferente finisării şi decorării camerelor de pe acest drum să fie minimă. Deocamdată, doar aceste camere vor fi aranjate…
Cerinţă
Scrieţi un program care să determine numărul m
de niveluri ale piramidei, suma minimă s
a tuturor costurilor aferente finisării şi decorării camerelor de pe un drum ce trece prin toate nivelurile piramidei, construit în modul descris în enunţ, precum şi un astfel de drum pentru care se obţine suma minimă, putând fi ales de scrib.
Date de intrare
Fișierul de intrare suma5.in
conține pe prima linie numărul natural nenul n
reprezentând numărul de camere din piramidă. A doua linie conţine n
numere naturale nenule c
1
, c
2
,…, c
n
, separate prin câte un spaţiu, reprezentând costurile aferente finisării şi decorării camerelor, în ordinea numerotării lor.
Date de ieșire
Fișierul de ieșire suma5.out
va conține pe prima linie două numere naturale m
şi s
, separate printr-un singur spaţiu, cu semnificaţia din enunţ. Cea de-a doua linie va conţine, separate prin câte un spaţiu, în ordinea parcurgerii lor, numerele camerelor de pe un drum ce trece prin toate nivelurile piramidei, drum pentru care se obţine suma minimă s
.
Restricții și precizări
1 ≤ n ≤ 63365
- Pentru fiecare valoare
n
citită se poate construi în modul descris în enunţ o piramidă în trepte cu n camere 1 ≤ c
1
, c
2
,…, c
n
<100
- Dacă există mai multe drumuri ce trec prin toate nivelurile piramidei şi pentru care se obţine suma minimă
s
, atunci drumul ales va fi cel mai mic drum din punct de vedere lexicografic. - Se acordă:
- 10% din punctaj pentru determinarea corectă a numărului
m
de niveluri ale piramidei - 30% din punctaj pentru determinarea corectă a sumei minime
s
- 60% din punctaj pentru determinarea corectă a drumului cerut.
- 10% din punctaj pentru determinarea corectă a numărului
Exemplu
suma5.in
14 7 8 4 5 5 8 4 2 7 7 8 3 1 6
suma5.out
3 13 1 3 8
Explicație
Piramida conţine 14
camere dispuse pe m=3
trei niveluri. Nivelurile conţin valorile:
Suma minimă s
a tuturor costurilor aferente finisării şi decorării camerelor de un drum ce trece prin toate cele 3
niveluri ale piramidei este 13
. Există mai multe drumuri pentru care se poate obţine suma minimă: [1,3,8]
, [1,4,13]
, [1,5,13]
. Din punct de vedere lexicografic, cel mai mic drum dintre aceste drumuri este: [1,3,8]
.
Cum e corect?
cout < "As la info";
cout << "As la info";
cout >> "As la info";
Felicitări! Poți mai mult?
Avem sute de probleme pentru tine, fiecare cu explicații ușor de înțeles.
Greșit, dar nu-i bai!
Antrenează-te cu sutele de probleme pe care ți le-am pregătit. Îți explicăm fiecare problemă în parte.
Rezolvare
Iată rezolvarea de 100 de puncte pentru problema Suma5:
//prof.Carmen Minca
#include <fstream>
using namespace std;
int a[58][58][58],t[58][58][58];
int n,k;
ifstream f("suma5.in");
ofstream g("suma5.out");
void citeste()
{
int i,l,c,x;
k=0;
f>>n;
for(i=1;i<=n;i++)
while (n>0)
{ k++;
for(l=1;l<=k;l++)
for(c=1;c<=k;c++)
{ f>>x;
t[k][l][c]=a[k][l][c]=x;
}
n=n-k*k;
}
g<<k<<;//nr niveluri
f.close();
}
void suma()
{ int i,l,c,x;
for(i=k-1;i>=1;i--)
for(l=1;l<=i;l++)
for(c=1;c<=i;c++)
{ if(t[i+1][l][c]<=t[i+1][l][c+1]) x=t[i+1][l][c];
else x=t[i+1][l][c+1];
if(x>t[i+1][l+1][c])x=t[i+1][l+1][c];
if(x>t[i+1][l+1][c+1])x=t[i+1][l+1][c+1];
t[i][l][c]=t[i][l][c]+x;
}
}
void drum()
{int c,l,i=1,s,nr=0;
s=t[1][1][1];
g<<s;
g<<endl<<1;
l=c=1;
do
{ nr=nr+i*i;
s=s-a[i][l][c]; i++;
if(s)
{if(t[i][l][c]==s) {l=l;c=c;}
else
if(t[i][l][c+1]==s)c=c+1;
else
if(s==t[i][l+1][c])l=l+1;
else {l=l+1;c=c+1;}
g<<<<nr+(l-1)*i+c; }
}while(s);
g<<endl;
g.close();
}
int main()
{citeste();
suma();
drum();
}
Atenție
Enunțurile afișate pe această pagină aparțin exclusiv site-ului PbInfo. Astfel, pentru ștergerea conținutului, puteți să ne contactați la adresa .
Rezolvarea problemei #1068 Suma5
Pe această pagină găsești rezolvarea de 100 de puncte pentru problema #1068 Suma5 de pe PbInfo.ro. Atenție: nu încurajăm copiatul codului! Totuși, credem cu tărie că analizarea unei soluții corecte este o metodă foarte ușoară de a învăța informatică, astfel că oferim sursele pentru peste 1500 de probleme de pe platforma PbInfo.ro.
Pentru rezolvări PbInfo de la peste 1500 de probleme, vă invităm să intrați pe site-ul nostru!