Afişează mesaje
Pagini: 1 2 3 [4]
76  infoarena - concursuri, probleme, evaluator, articole / .CAMPION / Spioni : Iulie 25, 2011, 12:04:52
Buna am si eu o problema de pe .campion si nush de ce imi pica la ultimu test la timpu de executie.... Brick wall.....chiar nu stiu ce sa  mai  fac.......Ma puteti ajuta? http://campion.edu.ro/arhiva/index.php?page=problem&action=view&id=573
Cod:
#include<cstdio>
using namespace std;
int x[1001],y[1001],s[1001];
int main(){
int n,xa=0,ya=0,k,i,j,gasit=0;
char c;
FILE * pFile;
pFile=fopen("spioni.in","r");
fscanf(pFile,"%d",&n);
for(i=1;i<=n;i++){
fscanf(pFile,"%d",&x[i]);
fscanf(pFile,"%d",&y[i]);
}
for(j=1;j<=n;j++){
if((x[j]==xa && y[j]==ya) || (x[j]==xa-1 && y[j]==ya-1) || (x[j]==xa && y[j]==ya-1) || (x[j]==xa+1 && y[j]==ya-1) || (x[j]==xa-1 && y[j]==ya) || (x[j]==xa+1 && y[j]==ya) || (x[j]==xa-1 && y[j]==ya+1) || (x[j]==xa && y[j]==ya+1) || (x[j]==xa+1 && y[j]==ya+1)){
s[j]=1;gasit=1;}
}
fscanf(pFile,"%d",&k);
for(i=1;i<=k+1;i++){
fscanf(pFile,"%c",&c);
switch(c){
case 'N':ya++;break;
case 'S':ya--;break;
case 'V':xa--;break;
case 'E':xa++;break;
}
for(j=1;j<=n;j++){
if((x[j]==xa && y[j]==ya) || (x[j]==xa-1 && y[j]==ya-1) || (x[j]==xa && y[j]==ya-1) || (x[j]==xa+1 && y[j]==ya-1) || (x[j]==xa-1 && y[j]==ya) || (x[j]==xa+1 && y[j]==ya) || (x[j]==xa-1 && y[j]==ya+1) || (x[j]==xa && y[j]==ya+1) || (x[j]==xa+1 && y[j]==ya+1)){
s[j]=1;gasit=1;}
}
}
pFile=fopen("spioni.out","w");
if(!gasit)fprintf(pFile,"-1");
else {
for(i=1;i<=n;i++){
if(s[i])fprintf(pFile,"%d\n",i);
}
}
return 0;
}
77  infoarena - concursuri, probleme, evaluator, articole / Probleme externe / Răspuns: Problema OJI 2009 : Iulie 08, 2011, 15:54:22
Mersi mult pentru ajutor Thumb up 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 Winner 1st place si pentru timpu pierdut sa ma ajuti ca ma inteles ff greu
78  infoarena - concursuri, probleme, evaluator, articole / Probleme externe / Răspuns: Problema OJI 2009 : 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.... Brick wall
Ma puteti ajuta ??(folosesc Mingw Developer Studio)
Cod:
#include<cstdio>
#include<string>
using namespace std;
int v[100];
int main(){
string ing[100],sc;
char c;
int t,tt=0,i=0,gasit=0,jmax=0,n,m,j,man;
FILE * pFile;
pFile = fopen ("reteta.in","r");
while (!feof(pFile)){
fscanf(pFile,"%c",&c);
if(c==')'){fscanf(pFile,"%d",&t);
tt=tt+t;}
if(c>='a' && c<='z'){
i++;
ungetc(c,pFile);
fscanf(pFile,"%s",&ing[i]);
}
if(c>='0' && c<='9'){
ungetc(c,pFile);
fscanf(pFile,"%d",&v[i]);
}
}
while(gasit==0){
gasit=1;
for(j=1;j<=i;j++){
if(ing[j]>ing[j+1]){
sc=ing[j];
ing[j]=ing[j+1];
ing[j+1]=sc;
man=v[j];
v[j]=v[j+1];
v[j+1]=man;
gasit=0;
}
}
}
for(j=1;j<=i;j++){
if(ing[i]!="///"){
for(m=j+1;m<=i;m++){
if(ing[j]==ing[m]){
ing[m]="///";
v[j]=v[j]+v[m];
v[m]=-1;
}
}
}
}
pFile = fopen ("reteta.out","w");
fprintf(pFile,"%d",tt);
fprintf (pFile,"\n");
for(j=1;j<=i;j++){
if(ing[i]!="///"){
fprintf(pFile,"%s",ing[i]);
fprintf(pFile," ");
fprintf(pFile,"\n");
}
}
return 0;
}
79  infoarena - concursuri, probleme, evaluator, articole / Probleme externe / Răspuns: Problema OJI 2009 : 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>
using namespace std;
char mat[100][20];
int v[100];
int main(){
char c;
int t,tt=0,i=1,j=1,gasit=0,jmax=0,n,m;
FILE * pFile;
pFile = fopen ("reteta.in","r");
while (!feof(pFile)){
fscanf(pFile,"%c",&c);
if(c==')'){fscanf(pFile,"%d",&t);
tt=tt+t;}
if(c>='a' && c<='z'){
mat[i][j]=c;j++;gasit=1;}
if(c==' ' && gasit==1){fscanf(pFile,"%d",&v[i]);i++;gasit=0;
if(j>jmax){jmax=j;}
j=1;
}

}
pFile = fopen ("reteta.out","w");
fprintf(pFile,"%d",tt);
fprintf (pFile,"\n");
for(n=1;n<=i-1;n++){
for(m=1;m<=jmax;m++){
if(mat[n][m]!=0){fprintf(pFile,"%c",mat[n][m]);}
}
fprintf (pFile," ");
fprintf(pFile,"%d",v[n]);
fprintf (pFile,"\n");
}

return 0;
}
80  infoarena - concursuri, probleme, evaluator, articole / Probleme externe / Răspuns: Problema OJI 2009 : 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) Brick wall,daca imi mai poti explica un pic cum e cu functia aceea si acolo la citire poate reusesc....

81  infoarena - concursuri, probleme, evaluator, articole / Probleme externe / Răspuns: Problema OJI 2009 : 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
82  infoarena - concursuri, probleme, evaluator, articole / Probleme externe / Problema OJI 2009 : 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.............................
Pagini: 1 2 3 [4]
Powered by SMF 1.1.19 | SMF © 2006-2013, Simple Machines