Add a1/program.c
This commit is contained in:
		
							parent
							
								
									4f512191c7
								
							
						
					
					
						commit
						40686a542a
					
				
							
								
								
									
										61
									
								
								a1/program.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								a1/program.c
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,61 @@ | |||||||
|  | #include <stdio.h> | ||||||
|  | #include <string.h> | ||||||
|  | 
 | ||||||
|  | #define MAX_LEN 100 | ||||||
|  | 
 | ||||||
|  | // Стек для хранения открывающих скобок
 | ||||||
|  | char stack[MAX_LEN]; | ||||||
|  | int top = -1; | ||||||
|  | 
 | ||||||
|  | // Функция для добавления элемента в стек
 | ||||||
|  | void push(char c) { | ||||||
|  |     if (top < MAX_LEN - 1) { | ||||||
|  |         stack[++top] = c; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // Функция для извлечения элемента из стека
 | ||||||
|  | char pop() { | ||||||
|  |     if (top >= 0) { | ||||||
|  |         return stack[top--]; | ||||||
|  |     } | ||||||
|  |     return '\0';  // Если стек пустой
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // Функция для проверки соответствия скобок
 | ||||||
|  | int isMatchingPair(char open, char close) { | ||||||
|  |     return (open == '(' && close == ')') || | ||||||
|  |            (open == '{' && close == '}') || | ||||||
|  |            (open == '[' && close == ']') || | ||||||
|  |            (open == '<' && close == '>'); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | int main() { | ||||||
|  |     char code[MAX_LEN]; | ||||||
|  |     printf("Enter the code: "); | ||||||
|  |     fgets(code, MAX_LEN, stdin); | ||||||
|  | 
 | ||||||
|  |     printf("Read: %s", code); | ||||||
|  | 
 | ||||||
|  |     for (int i = 0; i < strlen(code); i++) { | ||||||
|  |         char c = code[i]; | ||||||
|  | 
 | ||||||
|  |         if (c == '(' || c == '{' || c == '[' || c == '<') { | ||||||
|  |             push(c); | ||||||
|  |         } else if (c == ')' || c == '}' || c == ']' || c == '>') { | ||||||
|  |             char lastOpen = pop(); | ||||||
|  |             if (!isMatchingPair(lastOpen, c)) { | ||||||
|  |                 printf("Crossed bracket %c in %d, expected %c\n", c, i + 1, lastOpen); | ||||||
|  |                 return 1; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     if (top != -1) { | ||||||
|  |         printf("Unclosed bracket %c\n", stack[top]); | ||||||
|  |         return 1; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     printf("All brackets OK\n"); | ||||||
|  |     return 0; | ||||||
|  | } | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user