create a1
This commit is contained in:
		
							parent
							
								
									a56eaf1028
								
							
						
					
					
						commit
						1833160385
					
				
							
								
								
									
										60
									
								
								a1/program.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								a1/program.c
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,60 @@ | ||||
| #include <stdio.h> | ||||
| #include <string.h> | ||||
| 
 | ||||
| #define MAX_LENGTH 100 | ||||
| 
 | ||||
| int isMatchingPair(char open, char close) | ||||
| { | ||||
|     return (open == '(' && close == ')') || (open == '{' && close == '}') || (open == '[' && close == ']') || (open == '<' && close == '>'); | ||||
| } | ||||
| 
 | ||||
| int main() | ||||
| { | ||||
|     char input[MAX_LENGTH]; | ||||
|     fgets(input, sizeof(input), stdin); | ||||
|      | ||||
|     int len = strlen(input); | ||||
|     if (input[len - 1] == '\n') | ||||
|     { | ||||
|         input[len - 1] = '\0'; | ||||
|         len--; | ||||
|     } | ||||
| 
 | ||||
|     printf("Read: %s\n", input); | ||||
| 
 | ||||
|     char stack[MAX_LENGTH]; | ||||
| 
 | ||||
|     int top = -1; | ||||
| 
 | ||||
|     for (int i = 0; i < len; i++) | ||||
|     { | ||||
|         char ch = input[i]; | ||||
|         if (ch == '(' || ch == '{' || ch == '[' || ch == '<') | ||||
|         { | ||||
|             stack[++top] = ch; | ||||
|         } | ||||
|         else if (ch == ')' || ch == '}' || ch == ']' || ch == '>') | ||||
|         { | ||||
|             if (top == 0) | ||||
|             { | ||||
|                 printf("Crossed bracket %c in %d, expected opening bracket\n", ch, i); | ||||
|                 return 0; | ||||
|             } | ||||
|             else if (!isMatchingPair(stack[top], ch)) | ||||
|             { | ||||
|                 printf("Crossed bracket %c in %d, expected %c\n", ch, i, (stack[top] == '(' ? ')' : stack[top] == '{' ? '}' : stack[top] == '[' ? ']' : '>')); | ||||
|                 return 0; | ||||
|             } | ||||
|             top--; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     if (top != -1) | ||||
|     { | ||||
|         printf("Unmatched opening bracket %c\n", stack[top]); | ||||
|         return 0; | ||||
|     } | ||||
| 
 | ||||
|     printf("All brackets OK\n"); | ||||
|     return 0; | ||||
| } | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user