ºÝºÝߣ

ºÝºÝߣShare a Scribd company logo
Ministerul Educației și Cercetării
Centrul Național de Evaluare și Examinare
Probă scrisă la informatică Testul 8
Limbajul C/C++
Filieră teoretică, profil real, specializare matematică-informatică / matematică-informatică intensiv informatică
Filieră vocațională, profil militar, specializare matematică-informatică
Pagina 1 din 2
Examenul de bacalaureat național 2020
Proba E. d)
Informatică
Limbajul C/C++
Testul 8
Filieră teoretică, profil real, specializare matematică-informatică / matematică-informatică intensiv informatică
Filieră vocațională, profil militar, specializare matematică-informatică
• Toate subiectele sunt obligatorii. Se acordă 10 puncte din oficiu.
• Timpul de lucru efectiv este de 3 ore.
• Identificatorii utilizați în rezolvări trebuie să respecte precizările din enunț (bold), iar în lipsa unor
precizări explicite, notațiile trebuie să corespundă cu semnificațiile asociate acestora (eventual
în formă prescurtată). Datele de intrare se consideră corecte, validarea lor nefiind necesară.
• În grafurile din cerințe oricare arc/muchie are extremități distincte și oricare două arce/muchii
diferă prin cel puțin una dintre extremități.
SUBIECTUL I (20 de puncte)
Pentru fiecare dintre itemii de la 1 la 5, scrieți pe foaia de examen litera corespunzătoare răspunsului
corect. Fiecare răspuns corect se notează cu 4 puncte.
1. Indicați o expresie C/C++ care are valoarea 1 dacă și numai dacă numărul memorat în variabila
întreagă x aparține reuniunii de intervale [-2020,-2019][2019,2020].
a. x>=-2020 && x<=-2019 && x>=2019 && x<=2020
b. !(x<-2020 || x>-2019) || !(x<2019 || x>2020)
c. x>=-2020 || x<=-2019 || x>=2019 || x<=2020
d. !(x<-2020 && x>2020 && x>-2019 || x<2019)
2. Utilizând metoda backtracking se generează toate valorile naturale formate cu cifre ale numărului 578
și care sunt strict mai mici decât acesta. Primele șase numere generate sunt, în această ordine, 5, 55,
555, 557, 558, 57. Indicați al câtelea număr generat este 7.
a. al 10-lea b. al 9-lea c. al 8-lea d. al 7-lea
3. Variabila e este declarată alăturat. Indicați o instrucțiune de
atribuire corectă din punctul de vedere sintactic.
struct elev
{ int cod;
char initiala;
struct
{ int nota1,nota2;
}note;
}e;
a. e(initiala)=’A’; b. e=(2020,’A’,10,9);
c. e.cod=e.initiala-’A’; d. e.elev.cod=2020;
4. Subprogramele f1 și f2 sunt definite mai jos.
int f1 (int x, int y)
{ if(y==0) return x;
else return f1(x%y,y);
}
int f2(int x, int y)
{ if(x==y) return x;
else if(x>y) return f2(x-y,y);
else return f2(x,y-x);
}
La apel, returnează valoarea celui mai mare divizor comun al celor două numere naturale nenule primite
ca parametri:
a. atât f1 cât și f2 b. nici f1 nici f2 c. numai f1 d. numai f2
5. Un graf orientat cu 5 vârfuri este reprezentat prin matricea de adiacență alăturată.
Indicați numărul de vârfuri ale unui subgraf al acestuia care are un număr maxim de
vârfuri izolate.
0 0 1 0 0
1 0 1 1 0
0 0 0 0 0
0 0 1 0 1
0 0 1 0 0
a. 1 b. 2 c. 3 d. 4
Ministerul Educației și Cercetării
Centrul Național de Evaluare și Examinare
Probă scrisă la informatică Testul 8
Limbajul C/C++
Filieră teoretică, profil real, specializare matematică-informatică / matematică-informatică intensiv informatică
Filieră vocațională, profil militar, specializare matematică-informatică
Pagina 2 din 2
SUBIECTUL al II-lea (40 de puncte)
1. Algoritmul alăturat este reprezentat în pseudocod.
S-a notat cu a%b restul împărțirii numărului natural a la numărul natural
nenul b și cu [c] partea întreagă a numărului real c.
citește x,y
(numere naturale)
┌repetă
│ cx%10
│ x[x/10]
│┌dacă c≠0 atunci
││┌dacă y%10<c atunci
│││ yy*10+c
│││altfel
│││ yy*10-c
││└■
│└■
└până când x=0
scrie y
a. Scrieți valoarea afișată dacă se citesc, în această ordine, numerele
201920 și 20. (6p.)
b. Dacă numărul citit pentru y este 0, scrieți două numere din intervalul
[102,103) care pot fi citite pentru x, astfel încât, pentru fiecare dintre
acestea, în urma executării algoritmului, numărul afișat să fie 9. (6p.)
c. Scrieți programul C/C++ corespunzător algoritmului dat. (10p.)
d. Scrieți în pseudocod un algoritm echivalent cu cel dat, înlocuind structura
repetă...până când cu o structură repetitivă cu test inițial. (6p.)
2. Un graf neorientat cu 6 noduri, numerotate de la 1 la 6, este reprezentat prin listele de
adiacență alăturate. Pentru acest graf scrieți un lanț elementar, precum și un ciclu
care nu este elementar. (6p.)
1: 2,6
2: 1,4,6
3: 5,6
4: 2,5
5: 3,6
6: 1,2,3,5
3. Variabila i este de tip întreg, iar variabila s poate
memora un șir de cel mult 20 de caractere. Scrieți
ce se afișează în urma executării secvenței
alăturate. (6p.)
strcpy(s,"stilou"+4);
cout<<s<<endl; | printf("%sn",s);
strncpy(s,"stilou",4); s[4]='0';
for(i=0;i<4;i++)
if(i%2==0) s[i]=s[0]+i-1;
else s[i]=s[0]+3*(2*i/3-1);
cout<<s; | printf("%s",s);
SUBIECTUL al III-lea (30 de puncte)
1. Subprogramul suma are un singur parametru, n, prin care primește un număr natural (n[2,109]).
Subprogramul returnează suma divizorilor primi ai lui n. Scrieți definiția completă a subprogramului.
Exemplu: pentru n=12 subprogramul returnează 5 (divizorii primi ai lui 12 sunt 2 și 3). (10p.)
2. Scrieți un program C/C++ care citește de la tastatură numere naturale: n (n[2,20]), k (k[1,n]) și
n∙n numere din intervalul [0,109], elemente ale unui tablou bidimensional cu n linii și n coloane,
numerotate începând de la 1. Programul transformă tabloul în memorie, deplasând circular spre stânga,
cu câte o poziție, toate elementele situate pe linia k, în stânga diagonalei principale, ca în exemplu.
Elementele tabloului obținut sunt afișate pe ecran, fiecare linie pe câte o linie a ecranului, cu elementele
fiecărei linii separate prin câte un spațiu.
Exemplu: pentru n=6, k=4 și tabloul 1 2 3 4 5 6
6 7 8 9 0 1
2 4 6 8 0 2
1 3 5 7 9 5
6 2 7 4 5 7
3 9 4 8 5 7
se obține tabloul 1 2 3 4 5 6
6 7 8 9 0 1
2 4 6 8 0 2
3 5 1 7 9 5
6 2 7 4 5 7
3 9 4 8 5 7
(10p.)
3. Fișierul bac.in conține un șir de cel mult 106 numere naturale din intervalul [0,109], separate prin
câte un spațiu. Se cere să se afișeze pe ecran pozițiile din șir pe care se află termeni precedați de un
număr maxim de valori care au cifra unităților egală cu cifra unităților lor. Numerele afișate sunt separate
prin câte un spațiu. Proiectați un algoritm eficient din punctul de vedere al timpului de executare.
Exemplu: dacă fișierul bac.in conține numerele 112 12 5 25 88 15 2 19 32 179 35 621
pe ecran se afișează numerele de mai jos (termenii 32, respectiv 35 respectă proprietatea cerută):
9 11
a. Scrieți programul C/C++ corespunzător algoritmului proiectat. (8p.)
b. Descrieți în limbaj natural algoritmul proiectat, justificând eficiența acestuia. (2p.)

More Related Content

E d informatica_2020_sp_mi_c_var_test_08

  • 1. Ministerul EducaÈ›iei È™i Cercetării Centrul NaÈ›ional de Evaluare È™i Examinare Probă scrisă la informatică Testul 8 Limbajul C/C++ Filieră teoretică, profil real, specializare matematică-informatică / matematică-informatică intensiv informatică Filieră vocaÈ›ională, profil militar, specializare matematică-informatică Pagina 1 din 2 Examenul de bacalaureat naÈ›ional 2020 Proba E. d) Informatică Limbajul C/C++ Testul 8 Filieră teoretică, profil real, specializare matematică-informatică / matematică-informatică intensiv informatică Filieră vocaÈ›ională, profil militar, specializare matematică-informatică • Toate subiectele sunt obligatorii. Se acordă 10 puncte din oficiu. • Timpul de lucru efectiv este de 3 ore. • Identificatorii utilizaÈ›i în rezolvări trebuie să respecte precizările din enunÈ› (bold), iar în lipsa unor precizări explicite, notaÈ›iile trebuie să corespundă cu semnificaÈ›iile asociate acestora (eventual în formă prescurtată). Datele de intrare se consideră corecte, validarea lor nefiind necesară. • ÃŽn grafurile din cerinÈ›e oricare arc/muchie are extremități distincte È™i oricare două arce/muchii diferă prin cel puÈ›in una dintre extremități. SUBIECTUL I (20 de puncte) Pentru fiecare dintre itemii de la 1 la 5, scrieÈ›i pe foaia de examen litera corespunzătoare răspunsului corect. Fiecare răspuns corect se notează cu 4 puncte. 1. IndicaÈ›i o expresie C/C++ care are valoarea 1 dacă È™i numai dacă numărul memorat în variabila întreagă x aparÈ›ine reuniunii de intervale [-2020,-2019][2019,2020]. a. x>=-2020 && x<=-2019 && x>=2019 && x<=2020 b. !(x<-2020 || x>-2019) || !(x<2019 || x>2020) c. x>=-2020 || x<=-2019 || x>=2019 || x<=2020 d. !(x<-2020 && x>2020 && x>-2019 || x<2019) 2. Utilizând metoda backtracking se generează toate valorile naturale formate cu cifre ale numărului 578 È™i care sunt strict mai mici decât acesta. Primele È™ase numere generate sunt, în această ordine, 5, 55, 555, 557, 558, 57. IndicaÈ›i al câtelea număr generat este 7. a. al 10-lea b. al 9-lea c. al 8-lea d. al 7-lea 3. Variabila e este declarată alăturat. IndicaÈ›i o instrucÈ›iune de atribuire corectă din punctul de vedere sintactic. struct elev { int cod; char initiala; struct { int nota1,nota2; }note; }e; a. e(initiala)=’A’; b. e=(2020,’A’,10,9); c. e.cod=e.initiala-’A’; d. e.elev.cod=2020; 4. Subprogramele f1 È™i f2 sunt definite mai jos. int f1 (int x, int y) { if(y==0) return x; else return f1(x%y,y); } int f2(int x, int y) { if(x==y) return x; else if(x>y) return f2(x-y,y); else return f2(x,y-x); } La apel, returnează valoarea celui mai mare divizor comun al celor două numere naturale nenule primite ca parametri: a. atât f1 cât È™i f2 b. nici f1 nici f2 c. numai f1 d. numai f2 5. Un graf orientat cu 5 vârfuri este reprezentat prin matricea de adiacență alăturată. IndicaÈ›i numărul de vârfuri ale unui subgraf al acestuia care are un număr maxim de vârfuri izolate. 0 0 1 0 0 1 0 1 1 0 0 0 0 0 0 0 0 1 0 1 0 0 1 0 0 a. 1 b. 2 c. 3 d. 4
  • 2. Ministerul EducaÈ›iei È™i Cercetării Centrul NaÈ›ional de Evaluare È™i Examinare Probă scrisă la informatică Testul 8 Limbajul C/C++ Filieră teoretică, profil real, specializare matematică-informatică / matematică-informatică intensiv informatică Filieră vocaÈ›ională, profil militar, specializare matematică-informatică Pagina 2 din 2 SUBIECTUL al II-lea (40 de puncte) 1. Algoritmul alăturat este reprezentat în pseudocod. S-a notat cu a%b restul împărÈ›irii numărului natural a la numărul natural nenul b È™i cu [c] partea întreagă a numărului real c. citeÈ™te x,y (numere naturale) ┌repetă │ cx%10 │ x[x/10] │┌dacă c≠0 atunci ││┌dacă y%10<c atunci │││ yy*10+c │││altfel │││ yy*10-c ││└■ │└■ â””până când x=0 scrie y a. ScrieÈ›i valoarea afiÈ™ată dacă se citesc, în această ordine, numerele 201920 È™i 20. (6p.) b. Dacă numărul citit pentru y este 0, scrieÈ›i două numere din intervalul [102,103) care pot fi citite pentru x, astfel încât, pentru fiecare dintre acestea, în urma executării algoritmului, numărul afiÈ™at să fie 9. (6p.) c. ScrieÈ›i programul C/C++ corespunzător algoritmului dat. (10p.) d. ScrieÈ›i în pseudocod un algoritm echivalent cu cel dat, înlocuind structura repetă...până când cu o structură repetitivă cu test iniÈ›ial. (6p.) 2. Un graf neorientat cu 6 noduri, numerotate de la 1 la 6, este reprezentat prin listele de adiacență alăturate. Pentru acest graf scrieÈ›i un lanÈ› elementar, precum È™i un ciclu care nu este elementar. (6p.) 1: 2,6 2: 1,4,6 3: 5,6 4: 2,5 5: 3,6 6: 1,2,3,5 3. Variabila i este de tip întreg, iar variabila s poate memora un È™ir de cel mult 20 de caractere. ScrieÈ›i ce se afiÈ™ează în urma executării secvenÈ›ei alăturate. (6p.) strcpy(s,"stilou"+4); cout<<s<<endl; | printf("%sn",s); strncpy(s,"stilou",4); s[4]='0'; for(i=0;i<4;i++) if(i%2==0) s[i]=s[0]+i-1; else s[i]=s[0]+3*(2*i/3-1); cout<<s; | printf("%s",s); SUBIECTUL al III-lea (30 de puncte) 1. Subprogramul suma are un singur parametru, n, prin care primeÈ™te un număr natural (n[2,109]). Subprogramul returnează suma divizorilor primi ai lui n. ScrieÈ›i definiÈ›ia completă a subprogramului. Exemplu: pentru n=12 subprogramul returnează 5 (divizorii primi ai lui 12 sunt 2 È™i 3). (10p.) 2. ScrieÈ›i un program C/C++ care citeÈ™te de la tastatură numere naturale: n (n[2,20]), k (k[1,n]) È™i n∙n numere din intervalul [0,109], elemente ale unui tablou bidimensional cu n linii È™i n coloane, numerotate începând de la 1. Programul transformă tabloul în memorie, deplasând circular spre stânga, cu câte o poziÈ›ie, toate elementele situate pe linia k, în stânga diagonalei principale, ca în exemplu. Elementele tabloului obÈ›inut sunt afiÈ™ate pe ecran, fiecare linie pe câte o linie a ecranului, cu elementele fiecărei linii separate prin câte un spaÈ›iu. Exemplu: pentru n=6, k=4 È™i tabloul 1 2 3 4 5 6 6 7 8 9 0 1 2 4 6 8 0 2 1 3 5 7 9 5 6 2 7 4 5 7 3 9 4 8 5 7 se obÈ›ine tabloul 1 2 3 4 5 6 6 7 8 9 0 1 2 4 6 8 0 2 3 5 1 7 9 5 6 2 7 4 5 7 3 9 4 8 5 7 (10p.) 3. FiÈ™ierul bac.in conÈ›ine un È™ir de cel mult 106 numere naturale din intervalul [0,109], separate prin câte un spaÈ›iu. Se cere să se afiÈ™eze pe ecran poziÈ›iile din È™ir pe care se află termeni precedaÈ›i de un număr maxim de valori care au cifra unităților egală cu cifra unităților lor. Numerele afiÈ™ate sunt separate prin câte un spaÈ›iu. ProiectaÈ›i un algoritm eficient din punctul de vedere al timpului de executare. Exemplu: dacă fiÈ™ierul bac.in conÈ›ine numerele 112 12 5 25 88 15 2 19 32 179 35 621 pe ecran se afiÈ™ează numerele de mai jos (termenii 32, respectiv 35 respectă proprietatea cerută): 9 11 a. ScrieÈ›i programul C/C++ corespunzător algoritmului proiectat. (8p.) b. DescrieÈ›i în limbaj natural algoritmul proiectat, justificând eficienÈ›a acestuia. (2p.)