Fisa de lucru 5

Fisa de lucru-functii predefinite

1. Se citesc de la tastatură 3 cuvinte. Să se afişeze aceste cuvinte în ordinea crescătoare a lungimii lor.

2. Se citesc de la tastatură două cuvinte cu cel puţin 5 caractere fiecare. Să se schimbe primele 3 litere ale primului şir cu primele 3 litere ale celui de-al doilea şir şi invers.

3. Se citesc două cuvinte de caractere s şi d. Să se afişeze toate şirurile de caractere care se pot obţine prin concatenarea la şirul d a unui prefix a lui s.

4. Se citesc 3 cuvinte. Afişaţi cuvintele în ordine lexicografică.

5. Se citesc dintr-un fişier N cuvinte. Să se afişeze pe ecran, pe câte un rând, câte un cuvânt şi inversul cuvântului respectiv.

6. Se citesc din fişierul „cuvinte.in” N cuvinte. Să se scrie în „cuvinte.out” acele cuvinte citite care sunt palindrom.

7. Să se tipărească indicii tuturor apariţiilor unui caracter x într-un şir de caractere s.

8. Să se elimine toate apariţiile unui caracter x dintr-un şir s.

9. Să se tipărească indicii de start a tuturor apariţiilor unui subşir p într-un şir s.

10. Să se elimine dintr-un şir s toate apariţiile unui subşir p.

11. Să se înlocuiască toate apariţiile unui subşir e dintr-un şir s cu un alt subşir a;

12. Să se sorteze crescător lexicografic un şir de N cuvinte.

13. Se citeşte un text terminat cu ENTER. Cuvintele sunt despărţite prin spaţii, punte si virgule. Să se afişeze fiecare cuvânt din propoziţie pe cate un rând, şi în dreapta sa inversul său.

14. Se citeşte un text terminat cu ENTER. Cuvintele sunt despărţite prin spaţii, punte si virgule. Să se afişeze cel mai lung cuvânt palindrom din propoziţie.

15. Se citeşte un cuvânt.

a. Să se testeze dacă cuvântul este alcătuit exclusiv din caractere numerice;

b. Să se testeze dacă cuvântul este alcătuit exclusiv din caractere nenumerice;

c. Să se verifice dacă este format doar din vocale;

d. Să se verifice dacă este format doar din caractere care nu sunt vocale.

16. Se citesc două şiruri s şi d. Să se afişeze toate caracterele din s care aparţin lui d.

17. Se citeşte un şir de caractere care conţine şi cifre. Să se afişeze numerele naturale care se pot forma cu cifrele memorate pe poziţii consecutive din şirul dat. Calculaţi suma acestor numere.

Exemplu: abc45xz060k Se va afişa: 45, 60 Suma 105

18. În fişierul „numere.in” se memorează pe prima linie N. şi pe următoarele N linii numere naturale. Să se construiască un şir de caractere format prin concatenarea numerelor din fişier.

Ex.

3

123432

3342

2223

Atunci şirul va fi: 12343233422223

19. Se citeşte un text. Cuvintele sunt despărţite prin unul sau mai multe spaţii. Să se elimine toate apariţiile în exces ale caracterului spaţiu dintr-un text. De exemplu, dacă textul iniţial este „ Examenul la informatica ” , se va obţine textul ”Examenul la informatica”.

20. Se citesc din fişier text un text alcătuit din unul sau mai multe cuvinte. Cuvintele sunt separate printr-un singur spaţiu. Să se afişeze aceste cuvinte în ordine alfabetică şi apoi să se numere câte dintre ele încep şi se termină cu aceeaşi literă.

21. Se citeşte de la tastatură o propoziţie terminată cu punct. Cuvintele din propoziţie sunt separate prin caracterul virgulă şi prin caracterul spaţiu. După virgulă poate exista şi spaţiu. Se cere:

a. Să se afişeze cuvintele din propoziţie, fiecare pe câte un rând. Cuvintele vor fi afişate cu litere mici, exceptând prima literă care va fi majusculă.

b. Să se numere şi spaţiile se afişeze câte cuvinte conţine această propoziţie.

22. Se citeşte un text de la tastatură. Să se insereze după fiecare vocală codul ASCII corespunzător acesteia. Afişaţi textul modificat.

23. Sa se verifice daca un cuvant este palindrom.

24. Sa se transforme un sir din litere mici in litere mari.

25. Sa se transforme un sir din litere mari in litere mici.

26. Sa se determine frecventa de aparitie a unui caracter intr-un text.

27. Sa se genereze toate prefixele / sufixele unui cuvant.

28. Se citeste un text dintr-un fisier si un caracter c. Sa se determine de cate ori se gaseste caracterul in text (nu se face distinctie intre literele mari si literele mici).

29. Se citeste un text de la tastatura astfel incat cuvintele sa fie separate printr-un singur spatiu si imediat dupa ultimul cuvant se scrie punct. Textul va fi scris pe un singur rand.

a) Sa se determine cate cuvinte contine textul. De ex : "Ana are mere." Contine 3 cuvinte.

b) Sa se determine daca textul are cuvinte distincte (se ignora diferenta de cheie).

c) Sa se determine daca textul contine cifre.

30. Sa se determine de cate ori se gaseste un cuvant intr-un text.

31. Codificati un text astfel incat litera a sa devina c, b sa devina e s.a.m.d.

32. Sa se sorteze alfabetic un sir de cuvinte (eventual, fara a distinge literele mici de cele mari).

33. Codificarea pasareasca a unui cuvant (dupa fiecare vocala, se pune litera p urmata de acea vocala). Ex : informatica à ipinfopormapatipicapa

34. Se citesc n cuvinte. Sa se afiseseze grupurile de cuvinte care rimeaza (au ultimele 2 caractere identice).

35. Sa se desparta un text in cuvinte si sa se afiseze cuvintele separate. Sa se afiseze cuvantul de lungime maxima.

36. Sa se verifice daca doua cuvinte sunt sau nu anagrame.

37. Sa se numere aparitiile unui cuvant intr-un text.

38. Se citeste un numar real de la tastatura. Sa se trunchieze astfel incat cifrele ramase sa formeze o secventa monotona.

Ex. 34.59483 ®34.59 ; 24.1276 ® 24

39. Se citeste un sir de caractere alfanumerice. Consideram ca literele sunt separatorii numerelor. Afisati datele de tip numeric preluate in ordine din sirul citit. Numerele vor fi scrise cate unul pe o linie.

Ex.

in.txt out.txt

a23sc345ss5e 23

345

5

40. In directorul curent se afla fisierul cuvinte.txt care contine mai multe linii de text formate din cuvinte separate de cate un spatiu. Sa se afiseze cuvintele care au cel putin 3 consoane sau 3 vocale consecutive.

41. Se citeste un sir de caractere. Sa se afiseze sirul oglindit din care lipsesc vocalele.

42. Se da un text de maxim 30 de caractere. Sa se listeze toate cuvintele de doua caractere din acest text.

43. Se introduc de la tastatura cuvinte pana la citirea cuvantului stop. Afisati pe ecran cuvintele mai mari in sens lexicografic decat primul citit.

44. Se dau doua texte. Sa se stabileasca o vocala comuna celor doua texte, care apare de cele mai putine ori.

45. Dintr-un fisier se citeste un text. Textul contine cuvinte separate printr-un spatiu. Sa se determine cate cuvinte contine textul.

46. Dintr-un fisier se citeste un text. Textul contine cuvinte separate printr-un spatiu. Se va genera un nou text care va contine cuvintele ordonate alfabetic

47. Dintr-un fisier se citeste un text. Textul contine cuvinte separate printr-un spatiu. Sa se scrie intr-un alt fisier, pe linii separate, fiecare cuvant care apare in text urmat de un numar care va reprezenta de cate ori apare cuvantul in text. Sa se determine cuvantul care apare de cele mai multe ori.

48. Dintr-un fisier se citeste un text. Textul contine cuvinte separate printr-un spatiu. Intr-un alt fisier se va scrie pe linii separate fiecare cuvant si liniile pe care apare.

49. Dintr-un fisier se citeste un text. Textul contine cuvinte separate printr-un spatiu sau mai multe. Se va genera un nou fisier care va contine textul initial avand spatiile de prisos eliminate (intre cuvinte va ramane numai cate un spatiu).

50. Se citesc de la tastatura elementele unei matrici de caractere (nr. linii=nr. coloane), A(NXN), N<=10.

a) Sa se afiseze matricea A;

b) Sa se formeze si sa se afiseze cuvantul format din caracterele pe pe diagonala principala a matricii A;

c) Sa se calculeze si sa se afiseze numarul de litere mari, litere mici si cifre din matrice;

d) Sa se afiseze cuvantul format din caracterele de pe diagonala secundara;

e) Sa se afiseze procentul literelor mari, al literelor mici si al cifrelor de pe cele 2 diagonale;

f) Sa se afiseze caracterele comune aflate pe liniile p si q (p, q < N, p si q citite de la tastatura);

g) Sa se afiseze in ordine alfabetica, crescatoare, literele mari aflate pe coloanele impare.

51. Simulati comanda REPLACE astfel incat intr-un text veti inlocui un caracter x citit de la tastatura cu un alt caracter y citit de la tastatura. Se ignora sau nu diferenta de cheie dupa optiunea utilizatorului.

52. Simulati comanda REPLACE astfel incat intr-un text veti inlocui un sir x citit de la tastatura cu un alt caracter sir y citit de la tastatura. Se ignora sau nu diferenta de cheie dupa optiunea utilizatorului.

53. Se citeste de la tastatura un cuvant. Sa se stabileasca daca el contine doua litere alaturate identice, afisandu-se un mesaj corespunzator.

54. Dintr-un fisier se citesc numele a n persoane. Sa se modifice continutul fisierului astfel incat toate numele sa fie scrise astfel: prima litera mare si restul litere mici.

55. Se citesc n siruri. Pentru fiecare sir se va determina suma codurilor ASCII.

56. Intr-un fisier sunt scrise cuvinte pe linii separate. Sa se afiseze cuvintele care contin majuscule.

57. Intr-un fisier sunt scrise pe randuri diferite numele a n copii. Sa se modifice continutul fisierului astfel incat sa contina numele ordonate crescator.

58. Sa se afiseze vocalele unui cuvant.

59. Sa se afiseze cuvintele care incep si se termina cu consoana, (vocala) etc.

60. Sa se desparta un text in cuvinte si sa se afiseze cuvintele separate. Sa se afiseze cuvantul de lungime maxima.

61. Intr-un text exista un cuvant. Codificati/decodificati cuvantul dupa un algoritm generat de voi.

62. Aceeasi problema pentru un text.

63. Se dau doua texte. Sa se stabileasca o vocala comuna celor doua texte, care apare de cele mai putine ori.

64. Dintr-un fisier se citeste un text. Textul contine cuvinte separate printr-un spatiu. Sa se determine cate cuvinte contine textul.

65. Se citesc n cuvinte. Sa se afiseze perechile de 2 cuvinte care rimeaza.

66. Aceeasi problema, numai ca se vor afisa grupurilede cuvinte care rimeaza

67. Se citesc cuvinte pana la citirea cuvantului "stop". Sa se afiseze cate dintre cuvintele citite sunt egale cu primul cuvant citit.

68. Se citeste un text. Textul contine cuvinte separate printr-un spatiu. Se va genera un nou text care va contine cuvintele ordonate alfabetic

69. Se citeste un text. Textul contine cuvinte separate printr-un spatiu. Sa se scrie, pe linii separate, fiecare cuvant care apare in text urmat de un numar care va reprezenta de cate ori apare cuvantul in text. Sa se determine cuvantul care apare de cele mai multe ori.

70. Se citeste un text. Textul contine cuvinte separate printr-un spatiu. Sa se scrie, pe linii separate, fiecare cuvant si liniile pe care apare.

71. Se citeste un text care contine cuvinte separate printr-un spatiu sau mai multe. Se va genera un nou text care va contine textul initial avand spatiile de prisos eliminate (intre cuvinte va ramane numai cate un spatiu).

72. Simulati scrierea unei parole intr-un fisier. La tastarea parolei pe ecran in locul fiecarui caracter se va scrie caracterul '*'. Eventual realizati si incriptarea parolei inainte de a fi scrisa intr-un fisier.

73. Fie un sir de forma: cifra-litera, cifra litera …etc. Ex 2a4b5c. Sa se genereze un astfel de sir: aabbbbccccc.

74. Fie un sir format din replicarea de un numar de ori a unui subsir redundant. Sa se determine cea mai scurta secventa redundanta. Se va afisa subsirul redundant si numarul sau de aparitii. Ex pt: aabcaabcaabcaabc se va fisa: aabc si nu aabcaabc. Numarul de aparitii este 4 si nu 2.