Sunteți pe pagina 1din 4

FIȘĂ3 RECAPITULARE BACALAUREAT

1. Se consideră algoritmul de mai jos descris în pseudocod. S-a notat cu x%y restul împărţirii numărului natural
x la numărul natural nenul y şi cu [z] partea întreagă a numărului real z.
a) Scrieţi valoarea care se afişează dacă se citeşte numărul n=5172.
b) Scrieţi toate valori distincte, fiecare având exact patru cifre, care pot fi citite pentru variabila n astfel încât să
se afişeze valoarea 2008 în toate cazuri.
c) Scrieţi programul C/C++ corespunzător algoritmului dat.
d) Scrieţi în pseudocod un algoritm echivalent cu cel dat în care structura cât timp...execută să fie înlocuită cu o
structură repetitivă cu test final.
început
citeste n (număr natural)
m=0
P=1
┌cât timp n>0 execută început
│ c=n%10
│ ┌dacă c>0 atunci
│ │c=c-1
│ └■
│ m=m+c*p
│ p=p*10
│ n=[n/10]
└■sfârșit
scrie m
sfărșit
2. Fişierul date.in conţine un şir de cel mult un milion de numere naturale din intervalul [0,109], separate prin
câte un spațiu. Șirul are cel puțin doi termeni pari și cel puțin doi termeni impari. Se cere să se afișeze pe ecran
mesajul DA dacă șirul aflat în fișier are un subșir ordonat crescător, format din toți termenii pari ai săi, și un
subșir ordonat descrescător, format din toți termenii impari ai săi. Dacă nu există două astfel de subșiruri,
programul afișează pe ecran mesajul NU. Pentru verificarea proprietății cerute utilizați un algoritm eficient din
punctul de vedere al timpului de executare și al memoriei necesare.
Exemplu: dacă fişierul date.in conţine numerele 7 2 5 2 4 3 8 se afişează pe ecran mesajul DA iar dacă fișierul
conține numerele 5 2 7 2 4 3 8 se afişează pe ecran mesajul NU

3. În secvenţa de mai jos, variabila i este de tip întreg, iar variabila s memorează un şir de cel mult 20 de caractere,
numai litere mici ale alfabetului englez. Scrieţi instrucțiunile care pot înlocui punctele de suspensie astfel încât,
în urma executării secvenţei obținute, să se afişeze pe ecran toate literele şirului memorat în variabila s, cu
excepţia grupului de litere ae. Literele se afişează în ordinea apariţiei lor în şir. Exemplu: dacă şirul memorat
în variabila s este elaeagnaceae se afişează pe ecran elagnace
i=0;
while(i<strlen(s))
{. . . . . . . . . . . . . }

4. Scrieţi un program C/C++ care citeşte de la tastatură două numere naturale, m și n (2≤m≤20, 2≤n≤20), şi
construiește în memorie un tablou bidimensional A, cu m linii şi n coloane, astfel încât parcurgându-l linie cu
linie, de jos în sus, și fiecare linie de la dreapta la stânga, să se obțină șirul primelor n·m numere naturale,
impare, care NU sunt divizibile cu 3, ordonat strict crescător. Programul afișează pe ecran tabloul obținut,
fiecare linie a tabloului pe câte o linie a ecranului, elementele de pe aceeași linie fiind separate prin câte un
spațiu. Exemplu: pentru m=4 şi n=3 se obține tabloul alăturat.
35 31 29
25 23 19
17 13 11
7 5 1
5. Un număr natural nenul se numește subperfect dacă este strict mai mic decât suma divizorilor săi proprii
(divizori naturali diferiți de 1 și de el însuși). Exemplu: 12 este număr subperfect pentru că 12 <2+3+4+6
Se consideră subprogramul subperfect, cu doi parametri, a și b, prin care primeşte câte un număr natural
(2≤a≤b<109). Subprogramul afișează pe ecran, separate prin câte un spațiu, în ordine descrescătoare, toate
numerele subperfecte din intervalul [a,b]. Dacă în interval nu există astfel de numere, subprogramul afișează
pe ecran mesajul nu exista. Scrieţi definiţia completă a subprogramului. Exemplu: pentru a=10 și b=20, se
afișează pe ecran: 20 18 12

6. Variabila s poate memora un șir cu maximum 20 de caractere, iar variabila i este de tip întreg. Scrieți ce se afișează
în urma executării secvenței de instrucțiuni de mai jos.

strcpy(s,"BACALAUREAT");
cout<<strlen(s); i=0;
while (i<strlen(s)-1)
{
if(strchr("EAIOU",s[i])!=NULL) strcpy(s+i+1,s+i+2);
i++;
}
cout<<s;

7. Se consideră subprogramul f, definit alăturat. Scrieți două valori naturale distincte din intervalul [1,50] pe care
le poate avea variabila întreagă x, astfel încât f(30,x) să aibă valoarea 5.

int f(int a,int b)


{
if (b==0) return a;
else
return f(b,a%b);
}

8. Se consideră subprogramul dublu, cu doi parametri:


• n, prin care primeşte o valoare naturală 2<n<50
•v, prin care primeşte un tablou unidimensional cu n elemente, numere întregi cu cel mult 4 cifre. Cel puţin
unul dintre elementele tabloului este strict pozitiv.
După fiecare element strict pozitiv din tablou, subprogramul inserează câte un nou element, cu aceeaşi
valoare, ca în exemplu. Tabloul modificat, precum şi valoarea actualizată a lui n, sunt furnizate tot prin
parametrii v, respectiv n.
Scrieţi definiţia completă a subprogramului. Exemplu: dacă n=6 şi v=(4, -5, 0, 9, 9, -2), atunci după apel
n=9, iar v=(4, 4, -5, 0, 9, 9, 9, 9, -2).

9. S-a notat cu [z] partea întreagă a numărului real z, iar cu x%y restul împărţirii numărului natural x la numărul
natural nenul y.

a) Scrieţi valoarea care va fi afişată dacă se citeşte numărul x=140.


b) Scrieţi o valoare care poate fi citită pentru x (x≠1) astfel încât valoarea afişată să fie 6.
c) Scrieţi programul C/C++ corespunzător algoritmului dat.
d) Scrieţi valorile naturale din intervalul [7,28] care pot fi introduse pentru variabila x, astfel încât, după
executarea programului, valoarea afişată să fie 1.
citeşte x (număr natural)
s←0
f←2
┌cât timp x>1 execută
│ p←0
│┌cât timp x%f=0 execută
││ x← [x/f]
││ p←p+1
│└■
│┌dacă p≠0 atunci
││ s←s+p
│└■
│ f←f+1
└■
scrie s

10. Variabila x declarată alăturat memorează în câmpurile med1 şi med2 mediile semestriale ale unui elev. Scrieţi
expresia a cărei valoare va fi media anuală a acestui elev.

struct elev {
int matricol;
float med1,med2;
}x;

11. Scrieţi un program C/C++ care citeşte de la tastatură 4 numere naturale nenule m, n, x şi y (2<m≤10, 2<n≤20,
1≤x≤10, 1≤y≤10) şi elementele unui tablou bidimensional a cu m linii, numerotate de la 1 la m, si n coloane,
numerotate de la 1 la n; programul interschimbă elementele tabloului bidimensional de pe linia x cu cele de
pe linia y. Tabloul bidimensional astfel obţinut se va afişa pe ecran, câte o linie a tabloului pe câte o linie a
ecranului, cu un spaţiu între elementele fiecărei linii.

Exemplu: pentru m=4, n=3, x=1, y=3 şi matricea se va afisa

12. Care este numărul de circuite ale unui graf orientat cu 6 vârfuri numerotate de la 1 la 6, şi ale cărui arce sunt:
(2,1),(3,6),(4,1),(4,3),(4,5),(5,2), (6,4). Două circuite sunt distincte dacă diferă prin cel puţin un arc.

13. Fişierul text bac.txt conţine pe fiecare linie câte un număr întreg format din cel mult patru cifre. Se ştie că
fişierul conţine cel puţin un număr. Scrieţi un program eficient atât din punct de vedere al timpului de
executare cât şi din punct de vedere al spaţiului de memorie utilizat, care citeşte de la tastatură un număr real
x, apoi determină şi afişează acel număr din fişierul bac.txt care are valoarea cea mai apropiată de valoarea
lui x.

Exemplu: dacă fişierul bac.txt are conţinutul alăturat


4
-5
-6
-984
1345
-1,
iar de la tastatură se citeşte valoarea -3.85, programul va afişa valoarea -5.
a) Descrieţi succint, în limbaj natural, metoda de rezolvare folosită, explicând în ce constă eficienţa ei.
b) Scrieţi un program C/C++ care rezolvă problema conform metodei descrise.
14. Se consideră funcţia f care primeşte prin intermediul parametrului n un număr natural nenul (2≤n≤200), prin
intermediul parametrului a un tablou unidimensional care conţine n valori întregi (fiecare dintre aceste valori
întregi având cel mult patru cifre), iar prin intermediul parametrilor p1 şi p2 două valori naturale reprezentând
două poziţii din tablou (0≤p1≤p2<n). Numerotarea poziţiilor din tablou începe de la 0. Subprogramul
returnează valoarea -1 dacă cele mai multe valori din tabloul a, aflate între poziţiile p1 şi p2 inclusiv, sunt strict
negative, valoarea 0 dacă cele mai multe valori din a, aflate între poziţiile p1 şi p2 inclusiv, sunt nule, respectiv
valoarea 1 dacă cele mai multe valori din tabloul a aflate între poziţiile p1 şi p2 inclusiv, sunt strict positive.
Scrieţi definiţia completă a funcţiei f.
15. Scrieţi definiţia completă a subprogramului impar, care primeşte prin parametrul x un tablou unidimensional
cu cel mult 100 de elemente numere naturale, fiecare având cel mult 9 cifre, iar prin parametrul n o valoare
naturală reprezentând numărul efectiv de elemente ale tabloului (1≤n≤100) şi afişează mesajul DA în cazul în
care printre elementele tabloului x se află cel puţin un număr impar, sau afişează mesajul NU în caz contrar.

S-ar putea să vă placă și