#2497
Gigel este curios să afle în ce zonă a țării au trăit cei mai mulți dintre strămoșii săi. El reușește să adune informații despre structura genetică a persoanelor din diferite părți ale țării și speră că, prin compararea cu propria structură genetică, să identifice o zonă pătratică în care au trăit cei mai mulți dintre strămoșii săi.
Structura genetică a unei persoane este reprezentată sub forma unei secvențe cu cel mult 20 de caractere (litere mici ale alfabetului englez). O persoană poate fi considerată strămoș a lui Gigel dacă gradul de similaritate dintre secvența corespunzătoare persoanei respective și cea a lui Gigel este mai mare strict decât un număr K, cunoscut.
Gradul de similaritate dintre două secvențe este reprezentat de numărul de caractere comune celor două secvențe. De exemplu pentru secvențele abcdabd și acbdaad gradul de similaritate este 6 (2 caractere a, 2 caractere d, 1 caracter b, 1 caracter c).
Gigel reprezintă harta țării sub forma unui tablou bidimensional cu N linii și M coloane în care fiecare element reprezintă structura genetică a unei persoane din zona respectivă.
Cunoscând N , M , K , structura genetică pentru Gigel și reprezentarea hărții identificată de acesta, să se determine:
1) poziția pe hartă și structura genetică pentru persoana, sau persoanele, pentru care gradul de similaritate cu structura genetică a lui Gigel este maxim;
2) o zonă pătratică, de dimensiune maximă în care toate persoanele ar putea fi strămoși ai lui Gigel.
ONIG 2018
| Problema | gene | Operații I/O |
gene.in/gene.out
|
|---|---|---|---|
| Limita timp | 0.5 secunde | Limita memorie |
Total: 64 MB
/
Stivă 32 MB
|
| Id soluție | #54270465 | Utilizator | |
| Fișier | gene.c | Dimensiune | 1.60 KB |
| Data încărcării | 24 Noiembrie 2024, 12:36 | Scor/rezultat | 20 puncte |
gene.c: In function 'main': gene.c:22:5: warning: format '%c' expects argument of type 'char *', but argument 3 has type 'int *' [-Wformat=] fscanf(fin,"%c",&adn[i]); ^ gene.c:26:9: warning: format '%c' expects argument of type 'char *', but argument 3 has type 'int *' [-Wformat=] fscanf(fin,"%c",&adn[i]); ^ gene.c:33:13: warning: format '%c' expects argument of type 'char *', but argument 3 has type 'int *' [-Wformat=] fscanf(fin,"%c",&nr[i][j][1]); ^ gene.c:39:17: warning: format '%c' expects argument of type 'char *', but argument 3 has type 'int *' [-Wformat=] fscanf(fin,"%c",&nr[i][j][lx]); ^ gene.c:17:23: warning: variable 'l' set but not used [-Wunused-but-set-variable] int c, n, m, min, l, j, lx, x,jj; ^ gene.c:20:11: warning: ignoring return value of 'fscanf', declared with attribute warn_unused_result [-Wunused-result] fscanf(fin,"%d%d%d%d ",&c,&n,&m,&min); ^ gene.c:22:11: warning: ignoring return value of 'fscanf', declared with attribute warn_unused_result [-Wunused-result] fscanf(fin,"%c",&adn[i]); ^ gene.c:26:15: warning: ignoring return value of 'fscanf', declared with attribute warn_unused_result [-Wunused-result] fscanf(fin,"%c",&adn[i]); ^ gene.c:33:19: warning: ignoring return value of 'fscanf', declared with attribute warn_unused_result [-Wunused-result] fscanf(fin,"%c",&nr[i][j][1]); ^ gene.c:39:23: warning: ignoring return value of 'fscanf', declared with attribute warn_unused_result [-Wunused-result] fscanf(fin,"%c",&nr[i][j][lx]); ^
| Test | Timp | Mesaj evaluare | Scor posibil | Scor obținut | ||
|---|---|---|---|---|---|---|
| 0 | Depășit | Limita de timp depășită | 5 | 0 | ||
| 1 | 0 secunde | OK. | 5 | 5 | ||
| 2 | 0.004 secunde | OK. | 5 | 5 | ||
| 3 | 0.048 secunde | OK. | 5 | 5 | ||
| 4 | 0.032 secunde | OK. | 5 | 5 | ||
| 5 | 0.044 secunde | Raspuns gresit. | 5 | 0 | ||
| 6 | 0.016 secunde | Raspuns gresit. | 5 | 0 | ||
| 7 | 0.024 secunde | Raspuns gresit. | 5 | 0 | ||
| 8 | 0.132 secunde | Raspuns gresit. | 5 | 0 | ||
| 9 | 0.152 secunde | Raspuns gresit. | 5 | 0 | ||
| 10 | 0 secunde | Raspuns gresit. | 5 | 0 | ||
| 11 | 0 secunde | Raspuns gresit. | 5 | 0 | ||
| 12 | 0.004 secunde | Raspuns gresit. | 5 | 0 | ||
| 13 | 0.032 secunde | Raspuns gresit. | 5 | 0 | ||
| 14 | 0.048 secunde | Raspuns gresit. | 5 | 0 | ||
| 15 | 0.04 secunde | Raspuns gresit. | 5 | 0 | ||
| 16 | 0.024 secunde | Raspuns gresit. | 5 | 0 | ||
| 17 | 0.044 secunde | Raspuns gresit. | 5 | 0 | ||
| 18 | 0.1 secunde | Raspuns gresit. | 5 | 0 | ||
| 19 | 0.164 secunde | Raspuns gresit. | 5 | 0 | ||
| Punctaj total | 20 | |||||
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema gene 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ă.