Teste de informatică pentru liceu, articole C#, C/C++, PHP
Rândul 1
Se acordă 2 puncte din oficiu
1. (3 puncte) Se introduce de la tastatură un text în care separarea cuvintelor se face prin cel puţin un spaţiu. Să se afişeze cuvântul cel mai scurt şi cuvântul cel mai lung precum şi numerele de ordine ale acestor cuvinte.
2. (3 puncte) Se citeşte de la tastatură un şir de caractere. Să se obţină un al doilea şir de caractere care să conţină numai caracterele distincte din primul şir.
3. (2 puncte) Se citesc de la tastatură două şiruri de caractere care conţin două numere reprezentate în baza 20 (cifrele sunt deci 0..9 şi a,b,c,d,e,f,g,h,i,j; deci cifra 10 este a, cifra 11 este b, ..., cifra 19 este j). Să se afişeze suma (sau diferenţa, la alegere!) dintre cele două numere.
Rândul 2
Se acordă 2 puncte din oficiu
1. (3 puncte) Se introduce de la tastatură un text în care separarea cuvintelor se face prin cel puţin un spaţiu. Să se afişeze cuvintele care conţin o singură consoană şi în rest numai vocale (de exemplu: apa, oaza, roua etc.)
2. (3 puncte) Se citesc de la tastatură două şiruri de caractere. Să se elimine din fiecare şir caracterele care sunt comune celor două şiruri.
3. (2 puncte) Se citesc de la tastatură două şiruri de caractere care conţin două numere reprezentate în baza 20 (cifrele sunt deci 0..9 şi a,b,c,d,e,f,g,h,i,j; deci cifra 10 este a, cifra 11 este b, ..., cifra 19 este j). Să se afişeze suma (sau diferenţa, la alegere!) dintre cele două numere.
Dan Pracsiu deţinător www.dponline.ro
Profesor, Liceul Teoretic "Emil Racoviță" Vaslui
Membru în Comisia Naţională a Olimpiadelor de Informatică
Pasiuni: istoria, călătoriile, fotografia, muzica clasică
String 16-12-2011 16:43:8
Descompui textul in cuvinte (cel mai bine e sa folosesti strtok). Apoi scrii o functie care numara vocalele dintr-un cuvant. Asta nu e greu, pentru ca sunt doar 5 vocale: a,e,i,o,u.
Dan Pracsiu 19-12-2011 22:14:48
#include<fstream>
if (lung < strlen(cuv[i]))
#include<iostream>
#include<cstring>
using namespace std;
char text[1000], cuv[100][30];
int n;
int main()
{
int i;
char *p;
ifstream fin("text.in");
fin.getline(text, 1000);
fin.close();
p = strtok(text," ");
while (p)
{
strcpy(cuv[n],p);
n++;
p = strtok(NULL," ");
}
int lung = 0, poz = 0;
for (i=0 ; i
{
poz = i;
lung = strlen(cuv[i]);
}
cout << "Lungimea maxima o are al " << poz+1 << "-lea cuvant";
return 0;
}
Liviu 7-11-2012 22:2:14
imi poate rezolva cineva problema urmatoare de programare orientata pe obiecte?
cu constructori, destructori, cu fisiere cpp, header etc.
Sa se proiecteze si sa se implementeze o clasa pentru secvente ordonate de siruri de caractere. Clasa trebuie sa permita rezolvarea urmatoarelor probleme:
- Crearea secventei de siruri;
- Afisarea secventei de siruri;
- Determinarea numarului de siruri din secventa;
- Inserearea un nou sir in secventa, astfel incat ea sa ramana ordonata;
- Eliminarea un sir din secventa;
- Cautarea un sir in secventa;
- Concatenarea a doua secvente de siruri intr-una singura (tot ordonata);
- Compararea lexicografica a doua secvente de siruri.
nykoll 17-11-2012 20:37:27
aceeasi prb o am si eu la oop :-s
Paula 6-12-2012 10:1:45
Buna! As dori sa stiu cum se rezolva problema 1 de la randul 2. Va multumesc!
Doru 6-1-2015 20:53:36
Buna! As dori sa stiu cum se rezolva problema 1 de la randul 2. Va multumesc!
am incercat dar nu am reusit