#1087
Cuvinte4
Se consideră un şir de cuvinte separate două câte două printr-un spaţiu. Fiecare cuvânt este caracterizat prin numărul de ordine care reprezintă poziţia lui în şirul de cuvinte (primul cuvânt are numărul de ordine 1
). Unui cuvânt i se pot aplica în mod repetat următoarele transformări: primul caracter al cuvântului (cel mai din stânga) se şterge de acolo şi se adaugă după ultimul caracter din cuvânt. Astfel, dintr-un cuvânt s
cu k
caractere se pot obţine alte k-1
cuvinte pe care le numim cuvinte obţinute din transformarea cuvântului s
. De exemplu, dintr-un cuvânt format din 4
caractere c1c2c3c4
, cuvintele obţinute prin transformarea lui sunt: c2c3c4c1
, c3c4c1c2
, c4c1c2c3
.
Se caută în şirul de cuvinte prima pereche de cuvinte vecine (a,b)
, în care al doilea cuvânt din pereche (cuvântul b)
este identic cu un cuvânt obţinut din transformarea lui a
. Dacă există o astfel de pereche, se şterge cuvântul b
din şir. Prin ştergerea cuvântului b
din şir, acesta va avea mai puţin cu un cuvânt! Se repetă operaţia de căutare de mai sus până când în şirul rămas nu mai există o pereche (a,b)
de cuvinte vecine, astfel încât b
să fie obţinut prin transformarea lui a
.
Se ştie că pe parcursul modificărilor, cuvintele nu-şi schimbă numerele de ordine pe care le-au avut iniţial.
Scrieţi un program care să citească şirul de cuvinte şi să afişeze:
a) numărul de ordine al primului cuvânt şters sau valoarea 0
în cazul în care nu se şterge niciun cuvânt
b) numerele de ordine ale cuvintelor rămase după finalizarea operaţiilor de modificare.
OJI 2010, Clasa a VII-a
Problema | Cuvinte4 | Operații I/O |
cuvinte4.in /cuvinte4.out
|
---|---|---|---|
Limita timp | 0.1 secunde | Limita memorie |
Total: 64 MB
/
Stivă 8 MB
|
Id soluție | #30788841 | Utilizator | |
Fișier | cuvinte4.cpp | Dimensiune | 1.15 KB |
Data încărcării | 20 Septembrie 2021, 13:22 | Scor / rezultat | Eroare de compilare |
cuvinte4.cpp: In function 'bool perm(char*, char*)': cuvinte4.cpp:18:41: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] for(int j = 0 ; j < strlen(x) - 1 ; ++j) ^ cuvinte4.cpp: In function 'int main()': cuvinte4.cpp:31:11: error: reference to 'cin' is ambiguous while(cin >> mat[n]) ^ cuvinte4.cpp:5:10: note: candidates are: std::ifstream cin ifstream cin("cuvinte4.in"); ^ In file included from /usr/include/i386-linux-gnu/c++/4.8/bits/stdc++.h:74:0, from cuvinte4.cpp:1: /usr/include/c++/4.8/iostream:60:18: note: std::istream std::cin extern istream cin; /// Linked to standard input ^ cuvinte4.cpp:51:5: error: reference to 'cout' is ambiguous cout << poz + 1 << endl; ^ cuvinte4.cpp:6:10: note: candidates are: std::ofstream cout ofstream cout("cuvinte4.out"); ^ In file included from /usr/include/i386-linux-gnu/c++/4.8/bits/stdc++.h:74:0, from cuvinte4.cpp:1: /usr/include/c++/4.8/iostream:61:18: note: std::ostream std::cout extern ostream cout; /// Linked to standard output ^ cuvinte4.cpp:53:9: error: reference to 'cout' is ambiguous cout << 0 << endl; ^ cuvinte4.cpp:6:10: note: candidates are: std::ofstream cout ofstream cout("cuvinte4.out"); ^ In file included from /usr/include/i386-linux-gnu/c++/4.8/bits/stdc++.h:74:0, from cuvinte4.cpp:1: /usr/include/c++/4.8/iostream:61:18: note: std::ostream std::cout extern ostream cout; /// Linked to standard output ^ cuvinte4.cpp:55:9: error: reference to 'cout' is ambiguous cout << vec[i] << ' '; ^ cuvinte4.cpp:6:10: note: candidates are: std::ofstream cout ofstream cout("cuvinte4.out"); ^ In file included from /usr/include/i386-linux-gnu/c++/4.8/bits/stdc++.h:74:0, from cuvinte4.cpp:1: /usr/include/c++/4.8/iostream:61:18: note: std::ostream std::cout extern ostream cout; /// Linked to standard output ^
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema Cuvinte4 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ă.