Detalii evaluare #46909614

Rezumat problemă

#1047 Patrat2

Cel mai mare observator astronomic din România și din Europa de Est, aflat la Galați, a captat o imagine a boltei cerești, ce surprinde toate stelele vizibile în acel moment. Imaginea este în format digital, codificată sub forma unui tablou bidimensional, cu N linii și M coloane. Fiecare element al tabloului conține un număr natural care reprezintă intensitatea luminoasă a unei stele.

Numim stea strălucitoare o stea care are intensitatea luminoasă mai mare decât a tuturor stelelor învecinate direct cu ea, pe orizontală, verticală sau diagonală. Numim constelație pătrată patru stele strălucitoare care se află plasate în colțurile unui pătrat cu laturile paralele cu marginile tabloului. Lungimea laturii unei constelații pătrate este egală cu numărul de stele din care este formată latura. O stea strălucitoare poate face parte din mai multe constelații pătrate.

Scrieți un program care să determine:

a) Numărul stelelor strălucitoare;
b) Numărul constelațiilor pătrate;
c) Lungimea laturii pătratului care reprezintă cea mai mare constelație pătrată.

Detalii

Problema Patrat2 Operații I/O patrat2.in/patrat2.out
Limita timp 0.6 secunde Limita memorie Total: 2 MB / Stivă 2 MB
Id soluție #46909614 Utilizator Oancea Teodor Stefan (Theodosius)
Fișier patrat2.c Dimensiune 821 B
Data încărcării 26 Noiembrie 2023, 18:29 Scor / rezultat 100 puncte

Evaluare


Mesaj compilare

patrat2.c:1:2: warning: #import is a deprecated GCC extension [-Wdeprecated]
 #import <stdio.h> 

  ^
patrat2.c:2:2: warning: #import is a deprecated GCC extension [-Wdeprecated]
 #import <stdlib.h>

  ^
patrat2.c:3:80: warning: return type defaults to 'int' [enabled by default]
 int r[]={1,-1,0,0,1,-1,1,-1},f[]={0,0,1,-1,1,-1,-1,1},n,m,i,**v,j,k,**u,c,l,p; main(){freopen("patrat2.in","r",stdin);freopen("patrat2.out","w",stdout);scanf("%d%d",&n,&m);v=(int**)calloc(n,sizeof(int*));u=(int**)calloc(n,sizeof(int*));for(i=0;i<n;i++)v[i]=(int*)calloc(m,sizeof(int)),u[i]=(int*)calloc(m,sizeof(int));for(i=0;i<n;i++)for(j=0;j<m;j++)scanf("%d",&v[i][j]),u[i][j]=0;for(i=0;i<n;i++)for(j=0;j<m;j++){for(k=0;k<8;k++) (((i+r[k]>=0)&&(i+r[k]<n)&&(j+f[k]<m)&(j+f[k]>=0)&&(v[i+r[k]][j+f[k]]>=v[i][j]))?(void)(k=9):(void)0);(k==8?(void)(u[i][j]=1,p++):(void)0);};for(i=0;i<n;i++)for(j=0;j<m;j++)if(u[i][j]==1)for(k=1;k<n-i&&k<m-j;k++)if(u[i+k][j+k]==1&&u[i+k][j]==1&&u[i][j+k]==1) {if(c<k)c=k;l++;};if(c)printf("%d\n%d\n%d",p,l,c+1);else printf("%d\n%d\n0",p,l);return 0;}
                                                                                ^
patrat2.c: In function 'main':
patrat2.c:3:94: warning: ignoring return value of 'freopen', declared with attribute warn_unused_result [-Wunused-result]
 int r[]={1,-1,0,0,1,-1,1,-1},f[]={0,0,1,-1,1,-1,-1,1},n,m,i,**v,j,k,**u,c,l,p; main(){freopen("patrat2.in","r",stdin);freopen("patrat2.out","w",stdout);scanf("%d%d",&n,&m);v=(int**)calloc(n,sizeof(int*));u=(int**)calloc(n,sizeof(int*));for(i=0;i<n;i++)v[i]=(int*)calloc(m,sizeof(int)),u[i]=(int*)calloc(m,sizeof(int));for(i=0;i<n;i++)for(j=0;j<m;j++)scanf("%d",&v[i][j]),u[i][j]=0;for(i=0;i<n;i++)for(j=0;j<m;j++){for(k=0;k<8;k++) (((i+r[k]>=0)&&(i+r[k]<n)&&(j+f[k]<m)&(j+f[k]>=0)&&(v[i+r[k]][j+f[k]]>=v[i][j]))?(void)(k=9):(void)0);(k==8?(void)(u[i][j]=1,p++):(void)0);};for(i=0;i<n;i++)for(j=0;j<m;j++)if(u[i][j]==1)for(k=1;k<n-i&&k<m-j;k++)if(u[i+k][j+k]==1&&u[i+k][j]==1&&u[i][j+k]==1) {if(c<k)c=k;l++;};if(c)printf("%d\n%d\n%d",p,l,c+1);else printf("%d\n%d\n0",p,l);return 0;}
                                                                                              ^
patrat2.c:3:126: warning: ignoring return value of 'freopen', declared with attribute warn_unused_result [-Wunused-result]
 int r[]={1,-1,0,0,1,-1,1,-1},f[]={0,0,1,-1,1,-1,-1,1},n,m,i,**v,j,k,**u,c,l,p; main(){freopen("patrat2.in","r",stdin);freopen("patrat2.out","w",stdout);scanf("%d%d",&n,&m);v=(int**)calloc(n,sizeof(int*));u=(int**)calloc(n,sizeof(int*));for(i=0;i<n;i++)v[i]=(int*)calloc(m,sizeof(int)),u[i]=(int*)calloc(m,sizeof(int));for(i=0;i<n;i++)for(j=0;j<m;j++)scanf("%d",&v[i][j]),u[i][j]=0;for(i=0;i<n;i++)for(j=0;j<m;j++){for(k=0;k<8;k++) (((i+r[k]>=0)&&(i+r[k]<n)&&(j+f[k]<m)&(j+f[k]>=0)&&(v[i+r[k]][j+f[k]]>=v[i][j]))?(void)(k=9):(void)0);(k==8?(void)(u[i][j]=1,p++):(void)0);};for(i=0;i<n;i++)for(j=0;j<m;j++)if(u[i][j]==1)for(k=1;k<n-i&&k<m-j;k++)if(u[i+k][j+k]==1&&u[i+k][j]==1&&u[i][j+k]==1) {if(c<k)c=k;l++;};if(c)printf("%d\n%d\n%d",p,l,c+1);else printf("%d\n%d\n0",p,l);return 0;}
                                                                                                                              ^
patrat2.c:3:158: warning: ignoring return value of 'scanf', declared with attribute warn_unused_result [-Wunused-result]
 int r[]={1,-1,0,0,1,-1,1,-1},f[]={0,0,1,-1,1,-1,-1,1},n,m,i,**v,j,k,**u,c,l,p; main(){freopen("patrat2.in","r",stdin);freopen("patrat2.out","w",stdout);scanf("%d%d",&n,&m);v=(int**)calloc(n,sizeof(int*));u=(int**)calloc(n,sizeof(int*));for(i=0;i<n;i++)v[i]=(int*)calloc(m,sizeof(int)),u[i]=(int*)calloc(m,sizeof(int));for(i=0;i<n;i++)for(j=0;j<m;j++)scanf("%d",&v[i][j]),u[i][j]=0;for(i=0;i<n;i++)for(j=0;j<m;j++){for(k=0;k<8;k++) (((i+r[k]>=0)&&(i+r[k]<n)&&(j+f[k]<m)&(j+f[k]>=0)&&(v[i+r[k]][j+f[k]]>=v[i][j]))?(void)(k=9):(void)0);(k==8?(void)(u[i][j]=1,p++):(void)0);};for(i=0;i<n;i++)for(j=0;j<m;j++)if(u[i][j]==1)for(k=1;k<n-i&&k<m-j;k++)if(u[i+k][j+k]==1&&u[i+k][j]==1&&u[i][j+k]==1) {if(c<k)c=k;l++;};if(c)printf("%d\n%d\n%d",p,l,c+1);else printf("%d\n%d\n0",p,l);return 0;}
                                                                                                                                                              ^
patrat2.c:3:356: warning: ignoring return value of 'scanf', declared with attribute warn_unused_result [-Wunused-result]
 int r[]={1,-1,0,0,1,-1,1,-1},f[]={0,0,1,-1,1,-1,-1,1},n,m,i,**v,j,k,**u,c,l,p; main(){freopen("patrat2.in","r",stdin);freopen("patrat2.out","w",stdout);scanf("%d%d",&n,&m);v=(int**)calloc(n,sizeof(int*));u=(int**)calloc(n,sizeof(int*));for(i=0;i<n;i++)v[i]=(int*)calloc(m,sizeof(int)),u[i]=(int*)calloc(m,sizeof(int));for(i=0;i<n;i++)for(j=0;j<m;j++)scanf("%d",&v[i][j]),u[i][j]=0;for(i=0;i<n;i++)for(j=0;j<m;j++){for(k=0;k<8;k++) (((i+r[k]>=0)&&(i+r[k]<n)&&(j+f[k]<m)&(j+f[k]>=0)&&(v[i+r[k]][j+f[k]]>=v[i][j]))?(void)(k=9):(void)0);(k==8?(void)(u[i][j]=1,p++):(void)0);};for(i=0;i<n;i++)for(j=0;j<m;j++)if(u[i][j]==1)for(k=1;k<n-i&&k<m-j;k++)if(u[i+k][j+k]==1&&u[i+k][j]==1&&u[i][j+k]==1) {if(c<k)c=k;l++;};if(c)printf("%d\n%d\n%d",p,l,c+1);else printf("%d\n%d\n0",p,l);return 0;}
                                                                                                                                                                                                                                                                                                                                                                    ^

Rezultat evaluare

Test Timp Mesaj evaluare Scor posibil Scor obținut
1 0 secunde Corect ! 5 5
2 0 secunde Corect ! 5 5
3 0 secunde Corect ! 5 5
4 0 secunde Corect ! 5 5
5 0 secunde Corect ! 5 5
6 0 secunde Corect ! 5 5
7 0 secunde Corect ! 5 5
8 0.004 secunde Corect ! 5 5
9 0 secunde Corect ! 5 5
10 0 secunde Corect ! 5 5
11 0 secunde Corect ! 5 5
12 0 secunde Corect ! 5 5
13 0.004 secunde Corect ! 5 5
14 0 secunde Corect ! 5 5
15 0.004 secunde Corect ! 5 5
16 0.004 secunde Corect ! 5 5
17 0.004 secunde Corect ! 5 5
18 0.004 secunde Corect ! 5 5
19 0.004 secunde Corect ! 5 5
20 0.004 secunde Corect ! 5 5
Punctaj total 100

Cum funcționează evaluarea?

www.pbinfo.ro permite evaluarea a două tipuri de probleme:

  • probleme la care rezolvarea presupune scrierea unui program complet
  • probleme la care rezolvarea presupune scrierea unei secvențe de program - câteva instrucțiuni, o listă de declarații, una sau mai multe funcții, etc.

Problema Patrat2 face parte din prima categorie. Soluția propusă de tine va fi evaluată astfel:

  • Programul sursă este compilat folosind compilatorul corespunzător. Dacă în urma compilării se obțin erori sau avertismente, acestea sunt afișate în această pagină.
  • Dacă programul a fost compilat, executabilul obținut va fi rulat, furnizându-i-se unul sau mai multe seturi de date de intrare, în concordanță cu restricțiile specifice problemei. Pentru fiecare set de date se obține un anumit punctaj, în raport cu corectitudinea soluției tale.

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ă.