Dev - C++ - Lectura de Caracteres

   
Vista:

Lectura de Caracteres

Publicado por Albano (2 intervenciones) el 29/08/2015 18:22:35
Buenas tardes los consulto porque, estoy estudiando programación, me plantearon un problema que no logro dar con el resultado y quisiera saber si me pueden ayudar.
Agradezco a quienes puedan ayudarme o darme una mano, que tengan un buen día..!

PROBLEMA:

11920347_10206188549245335_926334222_n
11917314_10206188549405339_317751267_n
11949533_10206188549485341_2087456503_n



SOLUCION PLANTEADA:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
#include <stdio.h>
 
int main ()
{
    FILE * entrada = fopen("entrada.in","r");
    FILE * salida = fopen("salida.out","w");
 
    char cadena[200];
    int k=0, i=0, r=0, b=0;
 
    fscanf(entrada, "%d", &k);
 
    for(r=0; r<k; r++)
    {
        for(i=0; i<200; i++)
        {
            fscanf(entrada, "%s", &cadena[i]);
            printf("%s", &cadena[i]);
            if(cadena[i]=='{')
            {
                b++;
            }
 
            if(cadena[i]=='}')
            {
                b--;
                if(b==0)
                {
                    if(cadena[i+1]==' ' || cadena[i+1]=='\0')
                    {
                        break;
                    }
                }
            }
        }
        char respaldo[50];
        int j=0;
 
        for(i=0; i<200; i++)
        {
            if(cadena[i]>='A'&& cadena[i]<='Z')
            {
                if(cadena[i+1]!=' ')
                {
                    respaldo[j]=cadena[i];
                    respaldo[j+1]=cadena[i+1];
                    respaldo[j+2]='.';
 
                    j+=3;
                }
                else
                {
                    respaldo[j]=cadena[i];
                    respaldo[j+1]='.';
 
                    j+=2;
                }
            }
        }
 
        int l=0;
        char ejem[100][l];
 
        fscanf(entrada, "%d", &l);
 
        for(i=0; i<l; i++)
        {
            for(j=0; j<100; j++)
            {
                fscanf(entrada, "%s", &ejem[i][j]);
 
                if(ejem[i][j]==';')
                {
                    break;
                }
            }
            ejem[i][j]='\n';
        }
 
        for(i=0;i<l;i++)
        {
            for(j=0;j<100;j++)
            {
                if(ejem[i][j]>='A' && ejem[i][j]<='Z')
                {
                    for(r=0; r<20;r++)
                    {
                        if(ejem[i][j]==respaldo[r])
                        {
                            fprintf(salida, "CORRECTO");
                        }
                        else
                        {
                            fprintf(salida, "INCORRECTO");
                        }
                    }
                }
            }
        }
    }
}
Valora esta pregunta
Me gusta: Está pregunta es útil y esta claraNo me gusta: Está pregunta no esta clara o no es útil
0
Responder