|
Titlul: Problema OJI 2009 Scris de: Vidrean Mihai din Iulie 02, 2011, 19:54:40 Buna am si eu o problema nu e chiar tema ci e pt olimpiada..........daca ma puteti ajuta un pik sa-mi dati cva idei.........
Mama mea este profesoară de informatică, dar îi place foarte mult să gătească. Recent am descoperit caietul ei de reţete, care arată foarte neobişnuit. Fiecare reţetă este scrisă pe un singur rând pe care sunt precizate produsele folosite, cantităţile, precum şi ordinea în care se execută operaţiile. De exemplu: (unt 50 zahar 250 ou 4)5 ceea ce înseamnă că se amestecă 50 grame unt cu 250 grame zahăr şi cu 4 ouă timp de 5 minute. Pentru fiecare produs mama foloseşte întotdeauna aceeaşi unitate de măsură, aşa că unităţile de măsură nu mai sunt precizate. Numele produsului este scris întotdeauna cu litere mici, iar produsele şi cantităţile sunt separate prin spaţii (unul sau mai multe). Produsele care se amestecă împreună sunt încadrate între paranteze rotunde; după paranteza rotundă închisă este specificat timpul de preparare. Evident, mama are şi reţeţe mai complicate: (((zahar 100 ou 3)5 unt 100 nuca 200)4 (lapte 200 cacao 50 zahar 100) 3)20 Să traducem această reţetă: se amestecă 100 grame zahăr cu 3 ouă timp de cinci minute; apoi se adaugă 100 grame unt şi 200 grame nucă, amestecând totul încă 4 minute. Se amestecă 200 ml lapte cu 50 grame de cacao şi 100 grame zahăr timp de 3 minute, apoi se toarnă peste compoziţia precedentă şi se amestecă totul timp de 20 minute. Observaţi că înainte sau după parantezele rotunde pot să apară sau nu spaţii. Cerinţă Dată fiind o reţetă să se determine timpul total de preparare, precum şi cantităţile necesare din fiecare produs. Date de intrare Fişierul de intrare reteta.in conţine pe prima linie un şir de caractere care reprezintă o reţetă. Date de ieşire Fişierul de ieşire reteta.out va conţine pe prima linie timpul total necesar pentru prepararea reţetei. Pe următoarele linii sunt scrise ingredientele în ordine lexicografică (ordinea din dicţionar), câte un ingredient pe o linie. Pentru fiecare ingredient este specificat numele urmat de un spaţiu apoi de cantitatea totală necesară. Restricţii 0 < Lungimea unei reţete ≤ 1000 1 ≤ Numărul de ingrediente ≤ 100 Numele unui ingredient este scris cu maxim 20 litere mici ale alfabetului englez. Timpii de preparare sunt numere naturale < 100 Cantităţile specificate în reţete sunt numere naturale < 1000 Pentru determinarea corectă a timpului total se acordă 30% din punctajul pe test; pentru determinarea corectă a timpului total şi afişarea corectă a ingredientelor (ordonate lexicografic) se acordă integral punctajul pe test. Exemple reteta.in (((zahar 100 ou 3)5 unt 100 nuca 200)4 (lapte 200 cacao 50 zahar 100) 3)20 reteta.out 32 cacao 50 lapte 200 nuca 200 ou 3 unt 100 zahar 200 Daca ma puteti ajuta vu o rezolvare de cls a9-a - a10-a............................. Titlul: Răspuns: Problema OJI 2009 Scris de: c a e n din Iulie 02, 2011, 20:15:19 Ai încercat aici (http://olimpiada.info/oji2009/index.php?cid=arhiva)? Nu dă și sursă, dar descrie soluția.
Titlul: Răspuns: Problema OJI 2009 Scris de: Vidrean Mihai din Iulie 02, 2011, 20:32:06 Da am vazut numai ca problema e ca nu prea stiu cum sa implementez.....daca imi puteti da niste indicatii
Titlul: Răspuns: Problema OJI 2009 Scris de: Simoiu Robert din Iulie 02, 2011, 21:59:55 Odata ai aici pe infoarena problema, poti incerca daca eventual vrei sa implementezi cam cat iei, sunt aceleasi teste ca si la OJI, http://infoarena.ro/problema/reteta2. Acum ca si o idee, ai putea face cam asa : pentru timpul total, ti-e clar ca trebuie sa aduni la sol fiecare numar X de dupa paranteze, si ai solutia. Adica pentru exemplu, ai asa :
Cod: (((zahar 100 ou 3) 5 unt 100 nuca 200) 4 (lapte 200 cacao 50 zahar 100)3)20 Cod: struct vector {Titlul: Răspuns: Problema OJI 2009 Scris de: Vidrean Mihai din Iulie 03, 2011, 13:42:38 citirea cum imi sugerezi sa o fac sa citestesc fiecare caracter adica cam asa??
while(f.eof()) f>>c; (char c) sau stii ceva mai simplu?? si inca ceva imi mai poti explica putin functia aceea de sortare ca nu am inteles foarte bine(deabia am terminat a 9-a si nu reusesc nici cum sa ma prind cum mere problema asta) ](*,),daca imi mai poti explica un pic cum e cu functia aceea si acolo la citire poate reusesc.... Titlul: Răspuns: Problema OJI 2009 Scris de: Simoiu Robert din Iulie 03, 2011, 17:13:01 Fii atent aici : daca ai de sortat un vector, vrei sa-l sortezi normal, te gandesti LOGIC asa : ma, daca am 2 elemente, a si b, eu trebuie sa-i spun acelei FUNCTII in ce relatie trebuie sa le fie ele DUPA SORTARE. Adica mai usor, el alege la un moment dat 2 elemente si le compara (V[ i ] si V[ j ]). Daca avem functia asa :
Cod: bool comp (int a, int b) {Cod: if (a < b) return 1; Cod: struct st {Cod: char S[MAX]; Titlul: Răspuns: Problema OJI 2009 Scris de: Vidrean Mihai din Iulie 04, 2011, 22:07:31 buna am reusit sa scriu un cod si problema e aproape gata( nu stiu daca nu pica la memorie)......ce mai trebuie sa fac este sa sortez o matrice si sa grupez elemntele.....ar fi o idee buna sa folosesc functia strcmp pe linia i si i+1 si sa le schimb daca codul caracterului este mai mic decat celalt si sa fac asta pana nu se mai face nici o schimbare.............poate ar fi o idee buna nu stiu desi poate e cam complicat si dureaza mult...........daca aveti alte idei mai simple??
va pun aici codul: Cod: #include<cstdio> Titlul: Răspuns: Problema OJI 2009 Scris de: Cristian Lambru din Iulie 05, 2011, 13:12:06 Salut :) !
Pana la olimpiada mai trebuie sa inveti functii si structuri :) ! Tu vei avea nevoie de o Structura care sa iti pastreze pentru fiecare ingredient in parte numele (sub forma de string) si cantitatea (int). Astfel vei avea un vector destructuri (pana la 100 de elemente in total), in care vei retine cele N posibile elemente. Dupa ce ai aflat toate ingredientele si cantitatea, ele trebuiesc sortate crescator dupa nume. In acest mod vei sorta vectorul de structuri, interschimband structurile intre ele, nu doar numele sau cantinatea. Ar trebui sa arate cam asa: Cod: typedef struct In concluzie vei sorta acest vector cu bubble sort si gata problema :) ! Mult succes si sper sa te ajute! Titlul: Răspuns: Problema OJI 2009 Scris de: Vidrean Mihai din Iulie 08, 2011, 13:04:32 Buna am reusit sa rezolv problema si cred ca e cat de cat bn numai ca atunci cand compileaza imi da o eroare ceva de genu return code -197.... ](*,)
Ma puteti ajuta ??(folosesc Mingw Developer Studio) Cod: #include<cstdio> Titlul: Răspuns: Problema OJI 2009 Scris de: Simoiu Robert din Iulie 08, 2011, 13:18:53 Nu merge sa citesti un STRING cu citirea din c. Eu ti-am modificat, am citit un string s[1005], si i-am atribuit lui ing[ i ] pe s. De asemenea cu afisarea, nu poti afisa un stirng cu citirea din c, am afisat string.c_str (), care converteste un string intr-un array de char (adica string din C), dar programul nu afiseaza bine. Te descurci tu de aici :
P.S. Se pare ca am gasit greseala, tu la sfarsit parcurgeai cu indicele j, si faceai (adica afisai si verificai) cu ing[ i ] in loc de ing[ j ]. Am modificat aia si am mai modificat sa nu iti afiseze aiureli, adica trebuie neaparat ca fiecare ingredient sa inceapa CU O LITERA MICA. Teoretic merge, o sa verific si o sa mai vad. P.S. Final : Am luat 100 puncte (http://infoarena.ro/job_detail/601931), aveai doua greseli : 1. Nu lasa niciodata limita la fix, pentru ca la tine v sa zicem era indexat de la 0->99, nu pana la 100 (v[100]), deci mai bine pui mai mult. Testul 3 avea spre exemplu 150 ingrediente (nu stiu cum de a aparut atat, dar asta e), si am pus mai mult limita (v[185]). 2. La bubble sort, aparea eroare cand j = i, adica aici : for(j=1; j<=i; j++). Cand j = i, el testeaza pe ing[j+1], care nu exista, adica care este "", si cum "" e mai mic, il interschimba, si o sa-l adauge pe prima pozitie, si astfel pierzi ultimul ingredient, care este pe pozitia j + 1. Astfel, stergi egalul de acolo, si lasi j < i, si astfel ai rezolvat problema. Cod: #include<cstdio> Titlul: Răspuns: Problema OJI 2009 Scris de: Vidrean Mihai din Iulie 08, 2011, 15:54:22 Mersi mult pentru ajutor :thumbup: am inteless acuma in sfasit ca nu stiam ca nu poti citi stringurile si scrie,si stiu de greseala aia cu i numai ca am corectat-o si am uitat sa salvez pt ca nu-mi mergea la faza cu stringurile....
No in orice caz ms foarte mult pentru ajutor :winner1: si pentru timpu pierdut sa ma ajuti ca ma inteles ff greu |