-
Notifications
You must be signed in to change notification settings - Fork 0
/
Exercício 06.c
114 lines (83 loc) · 1.8 KB
/
Exercício 06.c
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
102
103
104
105
106
107
108
109
110
111
112
113
114
/*Usando uma Pilha, escreva uma função que receba uma string e
verifique se a string está com todos os parênteses “fechados”.
Por exemplo, a string “(abc(ab(abc))ab)” está balanceada,
enquanto que a string “(a(abc(abc))” não está balanceada.*/
#include "stdio.h"
#include "string.h"
#include "stdlib.h"
#include "malloc.h"
typedef struct Estrutura {
char letra;
struct Estrutura* prox;
} No;
typedef struct {
No *topo;
} Pilha;
void inicializar(Pilha *p ){
p->topo = NULL;
}
void exibirPilha(Pilha p ){
No* no = p.topo;
printf("\nTopo-->[");
while(no != NULL){
printf("%c",no->letra);
if(no->prox != NULL){
printf(",");
}
no= no->prox;
}
printf("]");
}
void empilhar(char letra, Pilha *p ){
No* novoNo = (No*)malloc(sizeof(No));
novoNo->letra = letra;
novoNo->prox = p->topo;
p->topo = novoNo;
}
void empilharNaPilha(char frase [100], Pilha *p){
int i;
for(i = 0; i < strlen(frase); i++){
empilhar(frase[i],p);
}
}
char desempilhar(Pilha *p){
No* no = p->topo;
p->topo = p->topo->prox;
no->prox = NULL;
char letra = no->letra;
free(no);
return letra;
}
int verificarParente(Pilha p){
int i;
int parEsq=0;
int parDir=0;
No* no = p.topo;
while(no != NULL){
if(no->letra == ')' ){
parEsq++;
}
if(no->letra == '('){
parDir++;
}
no= no->prox;
i++;
}
if(parEsq != parDir){
return 0;
}
return 1;
}
void main(){
Pilha p;
inicializar(&p);
char frase[100];
printf("\nInforme uma palavra : ");
scanf("%s",frase);
strupr(frase);
empilharNaPilha(frase,&p);
printf("\nPilha : ");
exibirPilha(p);
printf("\n\nFrase : %s",frase);
printf("\nTodos os parentes estao fechados ? %d",verificarParente(p));
}